Přejít k navigační liště

Zdroják » JavaScript » PostCSS a CSSnext ještě dnes v produkci díky Webpack 2

PostCSS a CSSnext ještě dnes v produkci díky Webpack 2

Články JavaScript

LESS a SASS jsou mrtvé! Ať žije PostCSS a CSSnext! Pojdme se společně podívat na to, jak tyhle technologie dostat krok po kroku na produkční server ještě dnes. Využijeme k tomu nejnovější verzi Webpack.

Minulý týden Martin Michálek popsal ve svém článku PostCSS jako jednoduchou náhradu CSS preprocesoru. Pojďme se teď společně podívat na to, jak tyto technologii dostat na produkční prostředí. Využijeme k tomu nejnovější Webpack ve verzi 2.x a přihodím taky CSSNext, přestože Martinovy výhrady k tomuto nástroji chápu.

Aby těch novinek nebylo málo, budu v příkladu používat Yarn – jedná se o alternativu pro NPM od vývojářů Facebooku. Pokud Yarn neznáte, budete mít dnes možnost jej vyzkoušet.

Začneme instalací balíčků

Základem bude Webpack 2.x, který nám pomůže vyřešit distribuci výsledného CSS kódu, jeho sestavení a přípraví kód k distrubuci v podobě jediného CSS souboru.

yarn add --dev webpack

Dále si nainstalujeme postcss a jeho loader pro Webpack – postcss-loaders. Ten nám umožní tyto dvě technologie vzájemně propojit. Abychom mohli zdrojové CSS rozdělit do více souborů, přidáme postcss-import – ten nám vyřeší poporu pro CSS @import.

yarn add --dev postcss postcss-loader postcss-import

Přihodíme balíček postcss-cssnext, který nám umožní využít CSSNext.

yarn add --dev postcss-cssnext

Závěrem nainstalujeme extract-text-webpack-plugin, který nám pomůže s vytvořením statického CSS souboru. Poslední bude css-loaderstyle-loader, který zařídí fallback, pokud se nepovede extrahovat CSS soubory.

yarn add --dev extract-text-webpack-plugin css-loader style-loader

Jdeme to všechno propojit

Středobodem veškerého našeho snažení bude webpack.config.js, který obsahuje konfiguraci pro Webpack. Přidejte do sekce module pravidlo pro CSS soubory:

var ExtractTextPlugin = require("extract-text-webpack-plugin");
// ....
module.exports = {
 module: {
  rules: [
   {
    test: /\.css$/,
    use: ExtractTextPlugin.extract({
     fallback: "style-loader", // když se to nepovede
     use: ['css-loader', 'postcss-loader']
    })
   }
   // ...
  ]
 },
}

Vysledný CSS soubor budeme chtít ukládat do složky dist. Musíme tady patřičně nastavit output:

var path = require("path");
module.exports = {
  // ...
  output: {
    path: path.resolve(__dirname, 'dist'), // zde bude výsledek
    filename: '[name].bundle.js',
  }
  // ...
}

A následně použijeme extract-text-webpack-plugin, pro generování výsledného statického CSS souboru:

module.exports = {
  // ...
  plugins: [
    new ExtractTextPlugin("style.css"), // soubor pojmenujeme
  ]
  // ...
}

Dále nastavte resolve a context, čímž sdělí Webpacku, kde se budou naše zdrojáky nacházet:

module.exports = {
  context: path.resolve(__dirname, 'src'),
  // ...
  resolve: {
    modules: [path.resolve(__dirname, 'src'), 'node_modules'],
  },
  // ...
}

Závěrem nastavíme entrypoint – vstupní soubor, ze kterého budeme vycházet:

module.exports = {
  // ...
  entry: {
    app: './app.js'
  },
  // ...
}

Webpack máme připraven. Jdeme nastavit postcss – ten je možné nově konfigurovat prostřednictvím souboru postcss.config.js, do kterého vložíme následující kód:

 module.exports = {
   plugins: {
     'postcss-import': {},
     'postcss-cssnext': {
       browsers: ['last 2 versions', '> 5%'],
     },
   },
 };

Jdeme to spustit!

Do souboru src/app.js přidejte následující: import styles from './app.css'; . Vytvořte si soubor src/app.css a spusťte v příkazové řádce webpack:

./node_modules/.bin/webpack

Pokud se vše povedlo, tak máte vytvořen ve složce dist svůj první CSS soubor s využitím PostCSS, CSSNext a Webpack.

A co soubory?

Pokud budeme potřebovat načítat v CSS statické soubory, jako jsou například odkazy na obrázky v  url() , budete muset přidat jejich loader:

yarn add --dev img-loader file-loader url-loader

Do webpack.config.js si přidejte v sekci module další pravidlo:

module.exports = {
  module: {
    rules: [
       // ...
      {
         test: /\.(jpe?g|png|gif|svg)$/i,
         use: [ 'url-loader?limit=10000', 'img-loader' ]
      } 
     // ...
    ]
  }
  // ...
}

Závěrem

Všechny zdrojáky jsou volně k dispozici na Github – teď už stačí je akorát dostat do produkce :-)

Komentáře

Odebírat
Upozornit na
guest
0 Komentářů
Nejstarší
Nejnovější Most Voted
Inline Feedbacks
Zobrazit všechny komentáře

Cesta URL: co se děje, než se načte webová stránka

Když do adresního řádku prohlížeče napíšete webovou adresu a stisknete Enter, spustí se fascinující řetězec procesů, které propojují váš počítač s celým světem. Od překladu doménového jména na IP adresu, přes navázání šifrovaného spojení, až po vykreslení každého pixelu na obrazovce - to všechno se odehraje během zlomků sekundy. Pojďme se podívat, co se mezitím děje pod kapotou webu.

Stav SIMD v Rustu v roce 2025

Různé
Komentáře: 1
SIMD - neboli Single Instruction, Multiple Data - znamená, že procesor může jednou instrukcí zpracovat více datových prvků najednou. Typicky to znamená, že místo sčítání dvou čísel přičtete dvě sady čísel paralelně. To může přinést výrazné zrychlení například při zpracování obrazu, audia nebo numerických výpočtů. Pokud již SIMD znáte, tato tabulka je vše, co budete potřebovat. A pokud s SIMD teprve začínáte, tabulku pochopíte do konce tohoto článku