React

Example

You can see an example herearrow-up-right.

Created with create-react-app

This example shows how to set up PurgeCSS with create-react-app template.

Method 1 - Use craco

Custom PostCSS plugins (including PurgeCSS) can be added to Create React App apps using cracoarrow-up-right. Follow the craco installation instructionsarrow-up-right, then install the PurgeCSS PostCSS plugin and add it to the craco config:

npm i --save-dev @fullhuman/postcss-purgecss
// craco.config.js
const purgecss = require('@fullhuman/postcss-purgecss');

module.exports = {
  style: {
    postcss: {
      plugins: [
        purgecss({
          content: ['./src/**/*.html', './src/**/*.tsx', './src/**/*.ts'],
        }),
      ],
    },
  },
};

Method 2 - Run PurgeCSS CLI in postbuild

Add the following code in package.json

Method 3 - eject create-react-app

You need to ejectarrow-up-right in order to expose the webpack configuration offered by original create-react-app

Install the webpack plugin for PurgeCSS:

Now, modify the file config/webpack.prod.conf.js by adding the following code with the rest of the imports:

...and directly before new ManifestPlugin(...) in the plugins list, add this:

Results

This example is importing the bootstrap css framework. Without PurgeCSS, the base css file size is 138 kB. Using PurgeCSS, the base css file size is 4 kB

Last updated