Effortlessly migrate your CSS, inline styles, and preprocessors to UnoCSS
English | 简体中文
Transform your legacy CSS into modern, performant UnoCSS with zero configuration! This powerful tool automatically converts:
- 🎨 CSS classes → UnoCSS utilities
- 🖌️ Inline styles → Atomic classes
- 🎭 Sass/Less/Stylus → Pure UnoCSS
- ⚡ Bundle size reduction up to 70%
- 🔧 Smart conflict resolution
- 🐛 Debug mode for transparency
- 🎯 One-click rollback for safety
Perfect for modernizing legacy projects or optimizing performance. Works with Vue, React, Svelte, Astro, and more!
💡 Pro tip: If you're using Tailwind CSS, check out our sister project transformToTailwindcss.
npm i -g transform-to-unocss
npx transform-to-unocss@latest your-project-folder
# Transform entire directory
tounocss playground
# Transform with debug output
tounocss playground --debug
# Revert changes (if needed)
tounocss playground --revert
# Show help
tounocss --help
Before:
<template>
<div class="container">
<h1 class="title">Hello World</h1>
<p style="color: red; font-size: 16px;">This is a paragraph</p>
</div>
</template>
<style scoped>
.container {
max-width: 1200px;
margin: 0 auto;
padding: 20px;
background: linear-gradient(to right, #ff6b6b, #4ecdc4);
}
.title {
font-size: 24px;
font-weight: bold;
color: #333;
text-align: center;
}
</style>
After:
<template>
<div class="max-w-6xl mx-auto p-5 bg-gradient-to-r from-red-400 to-teal-400">
<h1 class="text-6 font-bold text-gray-8 text-center">Hello World</h1>
<p class="text-red text-4">This is a paragraph</p>
</div>
</template>
✨ 70% smaller bundle size and zero runtime overhead!
🔥 Vite (Recommended)
import { viteTransformToUnocss } from 'transform-to-unocss'
// vite.config.ts
import { defineConfig } from 'vite'
export default defineConfig({
plugins: [
viteTransformToUnocss({
include: ['**/*.vue', '**/*.tsx', '**/*.jsx'],
exclude: ['node_modules/**'],
debug: true, // Enable debug mode
}),
],
})
📦 Rollup
// rollup.config.js
import { rollupTransformToUnocss } from 'transform-to-unocss'
export default {
plugins: [
rollupTransformToUnocss({
include: ['**/*.vue', '**/*.tsx', '**/*.jsx'],
debug: false,
}),
],
}
⚡ Webpack
// webpack.config.js
const { webpackTransformToUnocss } = require('transform-to-unocss')
module.exports = {
plugins: [
webpackTransformToUnocss({
include: ['**/*.vue', '**/*.tsx', '**/*.jsx'],
exclude: ['node_modules/**'],
}),
],
}
🎯 Vue CLI
// vue.config.js
const { webpackTransformToUnocss } = require('transform-to-unocss')
module.exports = {
configureWebpack: {
plugins: [
webpackTransformToUnocss({
include: ['**/*.vue'],
debug: process.env.NODE_ENV === 'development',
}),
],
},
}
⚡ Esbuild
// esbuild.config.js
import { build } from 'esbuild'
import { esbuildTransformToUnocss } from 'transform-to-unocss'
build({
plugins: [
esbuildTransformToUnocss({
include: ['**/*.tsx', '**/*.jsx'],
}),
],
})
- ✅ CSS class selectors → UnoCSS utilities
- ✅ Inline styles → Atomic class attributes
- ✅ Preprocessors (Sass/Less/Stylus) → Pure UnoCSS
- ✅ Pseudo-classes (
:hover
,:focus
, etc.) - ✅ Media queries → Responsive classes
- ✅ Complex selectors → Smart parsing
- 🐛 Debug mode - Detailed transformation logs
- � One-click rollback - Safe change reversal
- 🎨 VS Code extension - To UnoCSS
- 📝 TypeScript support - Full type definitions
- 🚀 Zero configuration - Works out of the box
- ⚡ Vue 3/2 - Full support
- ⚛️ React - JSX/TSX support
- 🎭 Svelte - Native support
- 🚀 Astro - Component support
- 📄 HTML - Pure HTML files
import { transfromCode } from 'transform-to-unocss'
// Transform Vue component
const result = await transfromCode(vueCode, {
type: 'vue',
isRem: true,
debug: true,
})
// Transform React component
const result = await transfromCode(reactCode, {
type: 'tsx',
isJsx: true,
debug: false,
})
interface Options {
type?: 'vue' | 'tsx' | 'jsx' | 'html' | 'svelte' | 'astro'
isJsx?: boolean // Whether to use JSX syntax
isRem?: boolean // Whether to convert to rem units
debug?: boolean // Whether to enable debug mode
include?: string[] // File patterns to include
exclude?: string[] // File patterns to exclude
}
Project Type | Before | After | Reduction |
---|---|---|---|
Medium Vue Project | 245KB | 73KB | 70% ↓ |
React Application | 180KB | 54KB | 68% ↓ |
Enterprise Project | 890KB | 267KB | 72% ↓ |
Use the --debug
flag for detailed transformation information:
tounocss playground --debug
Debug output includes:
- 📝 File processing progress
- 🎯 CSS rule transformation details
- ⚡ Performance statistics
- 🔍 Conflict resolution process
- transform-to-unocss-core - Browser-side CSS transformation core
- To UnoCSS - VS Code extension
- transformToTailwindcss - Tailwind CSS transformer
We welcome all forms of contributions! Please check the Contributing Guide for details.
# Clone the repository
git clone https://github.com/Simon-He95/transform-to-unocss.git
# Install dependencies
pnpm install
# Development mode
pnpm dev
# Run tests
pnpm test
# Build project
pnpm build
Result: 70% smaller CSS bundle, better performance, and cleaner code! 🚀
We welcome all forms of contributions! Please check the Contributing Guide for details.
# Clone the repository
git clone https://github.com/Simon-He95/transform-to-unocss.git
# Install dependencies
pnpm install
# Development mode
pnpm dev
# Run tests
pnpm test
# Build project
pnpm build
We welcome contributions! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
If this project helped you, please consider:
- ⭐ Star this repository
- 🐛 Report issues
- 🔧 Contribute code
- ☕ Buy me a coffee
Your support keeps this project alive and improving! 🙏
Made with ❤️ by Simon He