CSS (PostCSS)
To motivate some of the following tips, here's an overview over how Parcel processes CSS files (in that order):
@parcel/transformer-postcss
: Applies.postcssrc
and might generate a CSS modules map@parcel/transformer-css
: Registers@import ...
andurl(...)
into Parcel's graph@parcel/packager-css
: Concat all CSS assets into a single bundle.@parcel/optimizer-cssnano
: Minify the bundle output from@parcel/packager-css
.
As you can see, each asset is processed individually by PostCSS and concatenated with the others afterwards.
Parcel reads PostCSS from these files (in that priority): .postcssrc
, .postcssrc.json
, .postcssrc.js
, postcss.config.js
.
ΒΆ CSS Modules
There are two ways to enable CSS modules:
- Either globally in the PostCSS config file (this way you can also configure the underlying
postcss-modules
plugin).
To change postcss-modules options, pass them via plugins
:
- Or on a per-file basis: by using the file extension
.module.css
(or.module.scss
, etc.).
ΒΆ CSS modules tree shaking
With scope hoisting, unused classes in CSS modules are removed if a namespace import (or a named import as above) is used:
ΒΆ Using postcss-import
Some PostCSS plugins (e.g. postcss-custom-properties
) potentionally need to access declarations from other @import
ed CSS assets.
If you do want to run PostCSS on the whole bundle, we recommend you use postcss-import
(to inline @imports
) and postcss-url
(to rewrite url(...)
expressions appropriately).
This isn't done by default because it would have a negative effect on caching (Parcel could't reuse unchanged CSS files anymore).