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...

相关推荐
excel2 分钟前
彻底理解缓冲区:从概念、背压到可运行的 Fetch 流式示例
前端
小蜜蜂嗡嗡2 小时前
【flutter对屏幕底部有手势区域(如:一条横杠)导致出现重叠遮挡】
前端·javascript·flutter
伍哥的传说4 小时前
Vue 3 useModel vs defineModel:选择正确的双向绑定方案
前端·javascript·vue.js·definemodel对比·usemodel教程·vue3.4新特性·vue双向绑定
胡gh8 小时前
页面卡成PPT?重排重绘惹的祸!依旧性能优化
前端·javascript·面试
言兴9 小时前
# 深度解析 ECharts:从零到一构建企业级数据可视化看板
前端·javascript·面试
山有木兮木有枝_9 小时前
TailWind CSS
前端·css·postcss
烛阴10 小时前
TypeScript 的“读心术”:让类型在代码中“流动”起来
前端·javascript·typescript
杨荧10 小时前
基于Python的农作物病虫害防治网站 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python
Moment11 小时前
毕业一年了,分享一下我的四个开源项目!😊😊😊
前端·后端·开源
程序视点12 小时前
Escrcpy 3.0投屏控制软件使用教程:无线/有线连接+虚拟显示功能详解
前端·后端