tailwind v3 升级 v4

官方升级指南:tailwindcss.com/docs/upgrad...

移除postcss.config.js,引入新插件

若你使用的是 vite 则可移除postcss.config.js,使用 @tailwindcss/vite 专用插件

arduino 复制代码
// postcss.config.js
export default {
  plugins: {
    - tailwindcss: {},
    - autoprefixer: {},
    + "@tailwindcss/postcss": {},
  },
};
javascript 复制代码
// vite.config.ts
import { defineConfig } from "vite";
+ import tailwindcss from "@tailwindcss/vite";
export default defineConfig({
  plugins: [
+   tailwindcss(),
  ],
});

依赖变更

移除依赖:autoprefixer | postcss

升级依赖:tailwindcss | prettier-plugin-tailwindcss

添加依赖:@tailwindcss/vite

引入tailwind样式

scss 复制代码
// tailwind.css
- @tailwind base;
- @tailwind components;
- @tailwind utilities;

+ @import 'tailwindcss';

Tailwind CSS v4 不能与 Sass、Less 或 Stylus 等 CSS 预处理器一起使用,你需要将 @tailwind 指令放在 .css 文件的开头,详见 Tailwind CSS - Compatibility

配置文件变更

v4 版本中将不会自动检测 tailwind.config.js 你需要使用 @config 指令手动加载它

less 复制代码
// tailwind.css
+ @config "../../tailwind.config.js";

实际测试过程中仅部分配置生效,需参考tailwind对应设置下的自定义样式配置

less 复制代码
/** @type {import('tailwindcss').Config} */
export default {
  content: ['./index.html', './src/**/*.{vue,js,ts,jsx,tsx}'],
  theme: {
    extend: {
      // 在 v4 中有效
      colors: {
        primary: '#ff6600',
        word: '#262626',
        rise: '#f22323',
        fall: '#00a000',
      },
      // 在 v4 中无效
      screens: {
        desktop: '1700px',
      },
    },
  },
  plugins: [],
};

最后改为

css 复制代码
// tailwind.css
@theme {
  --color-primary: #ff6600;
  --color-word: #262626;
  --color-rise: #f22323;
  --color-fall: #00a000;

  --breakpoint-desktop: 1700px;
}

.main-content-w {
  @apply max-desktop:w-[800px] w-[1060px];
}

.main-content {
  @apply max-desktop:w-[800px] w-[1060px] pt-5;
}

@tailwindcss/vite 目前仅支持ESM

之前由于某些项目工具原因,移除了package.json 中的 "type": "module",导致 Node.js 将 .js 文件视为 CommonJS 模块,而无法加载仅支持 ES 模块的包,后来发现项目工具已经支持了,就把 "type": "module" 加回来了

已有样式变更 及 其他部分部分

v4 对已有的部分clas做了样式调整,需参考升级文档进行全局替换,其他介绍部分,目前在项目中暂未使用,具体变更细节 参考官方升级指南:tailwindcss.com/docs/upgrad...

相关推荐
kyriewen5 分钟前
开源|Image Harvest v1.0.5:AI 智能标签 + Eagle 导出,设计师和开发者的图片工作流神器
前端·javascript·ai编程
wuhen_n11 分钟前
LangChain Memory 详解:实现 AI 连续对话不丢失上下文
前端·langchain·ai编程
wuhen_n27 分钟前
LangChain Function Call 实战:让 AI 调用自定义工具
前端·langchain·ai编程
DyLatte31 分钟前
很多人把坚持,误以为成长
前端·后端·程序员
yingyima42 分钟前
凌晨3点的警报声:定时任务监控与告警的最佳实践
前端
zach1 小时前
React中的兄弟通讯之发布订阅模式
前端·react.js
书中枫叶1 小时前
我用 Vue3 写了一个 Chrome 步骤录制插件:自动截图、本地存储、一键导出教程
前端·vue.js
达达尼昂1 小时前
AI Native 工程实践 : agent 自动化测试
前端·后端·架构
2501_940041741 小时前
前端工程化命题,覆盖性能/架构/交互
前端·交互
夜焱辰1 小时前
我花了3个月,把一个终端 AI Agent 搬进了浏览器——踩坑全记录
前端·agent