How to use Tailwind JIT with Laravel Mix

July 18, 2021

Tailwind CSS now has a just-in-time compilation mode ("JIT mode"), which compiles only the CSS classes you use as you use them, even during development.

To enable it with Laravel Mix, you first need to install Laravel Mix. If you're using the Breeze or Jetstream starter kits, you should already have Tailwind installed and a tailwind.config.js file already created.

Otherwise, run this command to install Tailwind CSS through npm and create a tailwind.config.js file:

npx tailwindcss init

Next, enable JIT mode in the Tailwind configuration file. In tailwind.config.js, set the mode to jit:

module.exports = {
    mode: 'jit'

Create a CSS file at resources/css/app.css and fill it with this, which will get expanded by Laravel Mix into the full Tailwind CSS classes:

@import 'tailwindcss/base';
@import 'tailwindcss/components';
@import 'tailwindcss/utilities';

Add this to your webpack.mix.js file, pointing to the CSS file you just created and compiling it (from resources/css/app.css to its final destination at public/css/app.css):

mix.postCss('resources/css/app.css', 'public/css', [

Lastly: if the following scripts aren't already in your package.json file, add them:

"scripts": {
    "dev": "npm run development",
    "development": "mix",
    "watch": "mix watch",
    "watch-poll": "mix watch -- --watch-options-poll=1000",
    "hot": "mix watch --hot",
    "prod": "npm run production",
    "production": "mix --production"

Now to use Tailwind JIT mode, run npm run watch and keep the terminal running while you edit HTML or Blade files. Your public/css/app.css file continuously be updated by Tailwind to match the classes that you've actually used.

A quick favor: was anything I wrote incorrect or misspelled, or do you still have questions? Please use this form to let me know or ask for help!