.agents/skills/unocss/references/integrations-vite.md
The Vite plugin is the most common way to use UnoCSS.
pnpm add -D unocss
// vite.config.ts
import UnoCSS from 'unocss/vite'
import { defineConfig } from 'vite'
export default defineConfig({
plugins: [
UnoCSS(),
],
})
Create config file:
// uno.config.ts
import { defineConfig, presetWind3 } from 'unocss'
export default defineConfig({
presets: [
presetWind3(),
],
})
Add to entry:
// main.ts
import 'virtual:uno.css'
Standard mode - generates global CSS injected via uno.css import.
import 'virtual:uno.css'
Injects generated CSS into Vue SFC <style scoped>.
UnoCSS({
mode: 'vue-scoped',
})
For Web Components using Shadow DOM:
UnoCSS({
mode: 'shadow-dom',
})
Add placeholder in component styles:
const template = document.createElement('template')
template.innerHTML = `
<style>
:host { ... }
@unocss-placeholder
</style>
<div class="m-1em">...</div>
`
Generates CSS per module with optional scoping.
Generates CSS per chunk on build for MPA.
Edit classes directly in browser DevTools:
import 'virtual:uno.css'
import 'virtual:unocss-devtools'
Warning: Uses MutationObserver to detect changes. Dynamic classes from scripts will also be included.
// vite.config.ts
import React from '@vitejs/plugin-react'
import UnoCSS from 'unocss/vite'
export default {
plugins: [
UnoCSS(), // Must be before React when using attributify
React(),
],
}
Note: Remove tsc from build script if using @unocss/preset-attributify.
Works out of the box with @vitejs/plugin-vue.
import extractorSvelte from '@unocss/extractor-svelte'
import UnoCSS from 'unocss/vite'
import { svelte } from '@sveltejs/vite-plugin-svelte'
export default {
plugins: [
UnoCSS({
extractors: [extractorSvelte()],
}),
svelte(),
],
}
Supports class:foo and class:foo={bar} syntax.
Same as Svelte, use sveltekit() from @sveltejs/kit/vite.
import UnoCSS from 'unocss/vite'
import solidPlugin from 'vite-plugin-solid'
export default {
plugins: [
UnoCSS(),
solidPlugin(),
],
}
import Preact from '@preact/preset-vite'
import UnoCSS from 'unocss/vite'
export default {
plugins: [
UnoCSS(),
Preact(),
],
}
import UnoCSS from 'unocss/vite'
import Elm from 'vite-plugin-elm'
export default {
plugins: [
Elm(),
UnoCSS(),
],
}
UnoCSS({
mode: 'shadow-dom',
shortcuts: [
{ 'cool-blue': 'bg-blue-500 text-white' },
],
})
// my-element.ts
@customElement('my-element')
export class MyElement extends LitElement {
static styles = css`
:host { ... }
@unocss-placeholder
`
}
Supports part-[<part-name>]:<utility> for ::part styling.
Visit http://localhost:5173/__unocss in dev mode to:
With @vitejs/plugin-legacy:
import legacy from '@vitejs/plugin-legacy'
import UnoCSS from 'unocss/vite'
export default {
plugins: [
UnoCSS({
legacy: {
renderModernChunks: false,
},
}),
legacy({
targets: ['defaults', 'not IE 11'],
renderModernChunks: false,
}),
],
}
By default, .js and .ts files are not extracted. Configure to include:
// uno.config.ts
export default defineConfig({
content: {
pipeline: {
include: [
/\.(vue|svelte|[jt]sx|html)($|\?)/,
'src/**/*.{js,ts}',
],
},
},
})
Or use magic comment in files:
// @unocss-include
export const classes = {
active: 'bg-primary text-white',
}