How to integrate tailwind and webpack

ynwd

ynwd

Posted on October 16, 2021

How to integrate tailwind and webpack

This is a basic foundation setup, for using tailwind in webpack. It will be used when using react.

.
├── package.json
├── postcss.config.js
├── src
│   ├── index.css
│   └── index.js
├── tailwind.config.js
└── webpack.config.js
Enter fullscreen mode Exit fullscreen mode

Clone our previous postcss repo: https://github.com/ynwd/postcss

Install tailwindss

npm i tailwindcss -D
Enter fullscreen mode Exit fullscreen mode

Create tailwind config

npx tailwindcss init
Enter fullscreen mode Exit fullscreen mode

This will create a minimal tailwind.config.js file at the root of your project:

module.exports = {
  purge: [],
  darkMode: false, // or 'media' or 'class'
  theme: {
    extend: {},
  },
  variants: {
    extend: {},
  },
  plugins: [],
}

Enter fullscreen mode Exit fullscreen mode

Update tailwind config to remove any unused classes for the smallest file size

module.exports = {
  purge: [
    './src/**/*.html',
    './src/**/*.js',
  ],
  darkMode: false, // or 'media' or 'class'
  theme: {
    extend: {},
  },
  variants: {},
  plugins: [],
}
Enter fullscreen mode Exit fullscreen mode

Update postcss config to use tailwind

module.exports = {
    plugins: [
        require('postcss-import'),
        require('tailwindcss'),
        require('autoprefixer'),
        require('cssnano')({
            preset: 'default',
        }),
    ],
};
Enter fullscreen mode Exit fullscreen mode

Include Tailwind in your CSS

/* src/index.css */
@tailwind base;
@tailwind components;
@tailwind utilities;
Enter fullscreen mode Exit fullscreen mode

Update entry point:

/* src/index.js */
import "./index.css"

Enter fullscreen mode Exit fullscreen mode

Compile

npx webpack
Enter fullscreen mode Exit fullscreen mode

You can get the final source code here: https://github.com/ynwd/postcss/tree/tailwind

💖 💪 🙅 🚩
ynwd
ynwd

Posted on October 16, 2021

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related