PostCSS and autoprefixing (postcss-loader)
PostCSS and autoprefixing (postcss-loader)
PostCSS is a CSS post-processing tool that can transform your CSS in a lot of cool ways, like autoprefixing, linting and more!
First enable it in webpack.config.js
:
// webpack.config.js
Encore
// ...
+ .enablePostCssLoader()
;
Then restart Encore. When you do, it will give you a command you can run to install any missing dependencies. After running that command and restarting Encore, you’re done!
Next, download any plugins you want, like autoprefixer
:
$ yarn add autoprefixer --dev
Next, create a postcss.config.js
file at the root of your project:
module.exports = {
plugins: {
// include whatever plugins you want
// but make sure you install these via yarn or npm!
// add browserslist config to package.json (see below)
autoprefixer: {}
}
}
That’s it! The postcss-loader
will now be used for all CSS, Sass, etc files. You can also pass options to the postcss-loader by passing a callback:
// webpack.config.js
Encore
// ...
+ .enablePostCssLoader((options) => {
+ options.config = {
+ // the directory where the postcss.config.js file is stored
+ path: 'path/to/config'
+ };
+ })
;
Adding browserslist to package.json
The autoprefixer
(and many other tools) need to know what browsers you want to support. The best-practice is to configure this directly in your package.json
(so that all the tools can read this):
{
+ "browserslist": [
+ "defaults"
+ ]
}
The defaults
option is recommended for most users and would be equivalent to the following browserslist:
{
+ "browserslist": [
+ "> 0.5%",
+ "last 2 versions",
+ "Firefox ESR",
+ "not dead"
+ ]
}
See browserslist for more details on the syntax.
This work, including the code samples, is licensed under a Creative Commons BY-SA 3.0 license.