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

Product Engineer: supermani, nebo falešná efektivita?

Stále více firem propouští produktové týmy a sází na jednu roli, která to zvládne celé sama. Product Engineer je člověk, který vymyslí produkt, implementuje ho a vyhodnotí výsledky. S ekosystémem AI agentů místo kolegů. Efektivita? Na první pohled určitě. Ale je rozdíl mezi tím dodávat víc a rychleji a skutečně být efektivní. Tenhle rozdíl firmy zatím moc neřeší.

EU AI Act: co musí vývojářské týmy vědět do 2. srpna 2026

Druhého srpna začnou v EU platit povinnosti pro poskytovatele i provozovatele high-risk AI systémů: posouzení shody, technická dokumentace a quality management na straně providerů, uchovávání logů a dohled nad provozem na straně deployerů. Samostatně vstupují v platnost transparentní pravidla pro chatboty, generativní AI a deepfaky, a ta se týkají všech, nejen high-risk systémů. Kdo nasazuje AI v recruitmentu, credit scoringu nebo HR hodnocení, je v zóně. Čekání na odklad přes Digital Omnibus je sázka na legislativní proces, který ještě neskončil. A kdo si myslí, že se ho to netýká, protože „jen používá ChatGPT" v use casu z Annexu III, pravděpodobně špatně přečetl nařízení.

Vibe coding a skutečná cena kódu, který nikdo nečte

AI
Komentáře: 1
Andrej Karpathy pojmenoval vibe coding v únoru 2025 jako víkendový experiment, kdy vývojář nečte kód a nechá AI dělat všechno. Collins Dictionary z toho udělal slovo roku, startupy kolem toho vyrostly na desítky miliard dolarů. Jenže nejrigoróznější nezávislá studie zjistila, že AI nástroje zkušené vývojáře zpomalují o 19 %, přestože si oni sami mysleli, že zrychlili o 20 %. Mezi tím, co o vibe codingu věříme, a tím, co o něm víme, zeje díra – a je načase se do ní podívat.