DEV Community

Cover image for Install Tailwind CSS v4 in a Vue 3 + Vite Project
Stephen Akugbe
Stephen Akugbe

Posted on

Install Tailwind CSS v4 in a Vue 3 + Vite Project

Tailwind CSS v4 is here, bringing a more streamlined installation process and performance improvements. However, if you check the official Tailwind CSS documentation, you might not find explicit installation instructions for Vue 3 with Vite. This guide will walk you through the process step-by-step.

What’s New in Tailwind CSS v4?

Tailwind CSS v4 introduces several improvements, including:

  • No PostCSS configuration required – You no longer need postcss.config.js.
  • Faster build times – Thanks to better optimizations.
  • New @tailwindcss/vite plugin – Tailwind now integrates more seamlessly with Vite.

Why Vue 3 Instead of Nuxt?

I'm sure you're wondering why I would need Vue 3 instead of just using Nuxt. Vue 3 is a great choice if you’re building a SPA or an SSR-ready app without the full complexity of Nuxt. Here’s why you might choose Vue over Nuxt:

  • Better Performance: Vue 3 is lightweight and doesn’t add the overhead that Nuxt brings.
  • More Control: With Vue 3, you decide how your app is structured rather than following Nuxt’s conventions.
  • No Need for SSR: If you don’t need server-side rendering (SSR) or static site generation (SSG), Vue 3 is simpler.
  • Faster Builds: Since Nuxt includes additional features, Vue 3 + Vite can be faster for development and deployment.

Installing Tailwind CSS v4 in Vue 3 + Vite

Step 1: Create a Vue 3 Project with Vite

If you don’t already have a Vue 3 project set up, create one using Vite:

npm create vite@latest my-vue-app -- --template vue
cd my-vue-app
npm install
Enter fullscreen mode Exit fullscreen mode

Step 2: Install Tailwind CSS v4

Run the following command to install Tailwind CSS v4 along with its Vite plugin:

npm install -D tailwindcss @tailwindcss/vite
Enter fullscreen mode Exit fullscreen mode

Step 3: Configure Vite to Use Tailwind CSS

Edit vite.config.ts (or vite.config.js if using JavaScript) and add Tailwind CSS as a plugin:

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import tailwindcss from '@tailwindcss/vite'

export default defineConfig({
  plugins: [
    vue(),
    tailwindcss(),
  ],
})
Enter fullscreen mode Exit fullscreen mode

Step 4: Add Tailwind to Your Styles

Edit the CSS file src/style.css and add:

@import 'tailwindcss';
Enter fullscreen mode Exit fullscreen mode

Step 5: Import Tailwind CSS in main.ts

Check your src/main.ts and ensure your style.css is imported:

import { createApp } from 'vue'
import App from './App.vue'
import './style.css'

createApp(App).mount('#app')
Enter fullscreen mode Exit fullscreen mode

Step 6: Start Your Development Server

Run the Vite development server:

npm run dev
Enter fullscreen mode Exit fullscreen mode

That’s it! You’ve successfully set up Tailwind CSS v4 in a Vue 3 project using Vite. With this new streamlined setup, you can enjoy faster builds and an even smoother development experience.

Have you tried Tailwind CSS v4 yet? Share your thoughts in the comments! 🚀

Top comments (14)

Collapse
 
oleksandr_pikush profile image
Oleksandr Pikush

it works

Collapse
 
qader_kamal_35fc1ecbcc7a1 profile image
Qader Kamal

I literally done this and it didnt work, but done the exact same thing from your guid and it worked, literally have no idea why, but cool lol

thanks

Collapse
 
osalumense profile image
Stephen Akugbe

So, just to clarify, you followed the guide and you were able to set it up right?

Collapse
 
tibering profile image
Tibering

├── @tailwindcss/postcss@4.1.4
├── @tailwindcss/vite@4.1.4
├── @vitejs/plugin-vue@5.2.3
├── autoprefixer@10.4.21
├── postcss@8.5.3
├── tailwindcss@4.1.4
├── vite@6.2.6
└── vue@3.5.13

it works

Collapse
 
diochuks profile image
Liam Dio

Thanks bud

Collapse
 
v3nt profile image
v3nt

How do you configure it though?

Collapse
 
biscoff_underfield_b40840 profile image
Biscoff Underfield

garbage - doesn't work - just some ai pollution

Collapse
 
varma_sagi_82f557ba2d8a09 profile image
Varma Sagi

works

Collapse
 
osalumense profile image
Stephen Akugbe

I'm sorry it didn't work for you, I only put this up after setting up a project in Vue3 with tailwind v4

Collapse
 
yvan_cito_eb6a346b49201ff profile image
Yvan Cito

this comment is garbage pollution =)

Collapse
 
viniciuzsk profile image
Vinícius Willian

Funcionou muito bem aqui! Obrigado!

Collapse
 
alkasadist profile image
Alexandr Andreev

works. tysm!

Collapse
 
arthur_bashirkwisongole_ profile image
ARTHUR BASHIR KWISONGOLE

It works

Collapse
 
esley_santana_868a75be670 profile image
Esley Santana

works