Tailwind CSS 生产环境部署优化与 CDN 使用规范

线上突然多了个警告,一看是 cdn.tailwindcss.com 的。本来还以为这个 CDN 也能凑合用,结果官方直接建议生产环境别用。想想也是,那个脚本没压缩就 2MB 多,而且不支持 JIT,没 tree-shaking,CSS 前缀也不加,放线上纯粹是拖慢首屏。

所以这个 CDN 只适合搞原型、临时演示或者自己学着玩。用法也简单,直接引一下:

xml 复制代码
<script src="https://cdn.tailwindcss.com"></script>

要自定义配置也支持,传参数或者内联 config。

xml 复制代码
<script src="https://cdn.tailwindcss.com?plugins=forms,typography"></script>
<script>
  tailwind.config = {
    theme: {
      extend: {
        colors: { clifford: '#da373d' }
      }
    }
  }
</script>

但注意,这玩意儿就图个快,别往生产丢。

生产环境还是得老老实实走构建流程。

npm 构建方案(推荐)

先装依赖:

csharp 复制代码
npm install -D tailwindcss postcss autoprefixer
npx tailwindcss init -p

然后改 tailwind.config.js,最重要的就是 content 字段,告诉它扫描哪些文件。这个容易配错,一旦没扫到,类名就直接被 purge 掉,样式就乱了。

css 复制代码
module.exports = {
  content: ['./src/**/*.{html,js}'],
  theme: {
    extend: {},
  },
  plugins: [],
}

开发的时候用 watch:

css 复制代码
npx tailwindcss -i ./src/input.css -o ./dist/output.css --watch

上线前跑一次 minify:

css 复制代码
npx tailwindcss -i ./src/input.css -o ./dist/output.css --minify

这行就足够生成压缩过的 CSS,不用再额外配 PurgeCSS,Tailwind 内置了。

如果还在用 Tailwind v2,记得在配置里显式开启 JIT:

java 复制代码
module.exports = {
  mode: 'jit',
  // ...
}

v3 默认就是 JIT 模式,不用手动加。

替代 CDN?不太推荐

有人可能想用 jsDelivr 上的预编译版:

ini 复制代码
<link href="https://cdn.jsdelivr.net/npm/tailwindcss@3.3.0/dist/tailwind.min.css" rel="stylesheet">

但版本固定,更新不及时,而且那个 CSS 也是全量的,虽然压缩过但依然很大,还是没用到按需生成。反正我是没用过这个方案上生产。

样式错乱怎么排查

大部分情况是 content 没配对。比如只写了 './src/**/*.html',结果你模板文件在 resources/views/ 下面,那 Tailwind 扫描不到,构建出来的 CSS 就是空的或者缺类。解决方法就是补全路径:

css 复制代码
content: ['./src/**/*.{html,js,jsx,ts,tsx}'],

如果项目结构复杂,多写几个路径,精准点,别用通配符扫太多无关目录,不然构建慢。

构建性能

content 路径范围太大,或者扫了 node_modules,构建速度会明显下降。所以尽量精确指定:

css 复制代码
content: [
  './app/**/*.{html,js}',
  './resources/views/**/*.blade.php'
]

这样既能保证类名不丢,构建也快。

部署时的一些顺手操作

开发阶段配个编辑器插件,Tailwind CSS IntelliSense,自动补全和提示用着舒服。类名排序可以用 rustywind 格式化一下,团队代码看着统一。

生产构建完,用 Lighthouse 跑一下性能,确保 CSS 体积正常。Nginx 那边配个长缓存,因为构建出来的 CSS 文件名可以带 hash,不怕更新:

bash 复制代码
location / {
  try_files $uri $uri/ /index.html;
  expires 1y;
  add_header Cache-Control "public";
}

这样静态资源都能强缓存。

基本就这些。核心就是别图省事把开发 CDN 直接扔生产,老老实实走构建,content 配准,上线 minify,缓存开起来。其他就是细节问题了。

相关推荐
共绩算力1 小时前
第四辑:8 张「印刷品与示意图」——几何海报到工间操
前端·数据库·人工智能·共绩算力
bug-100861 小时前
为什么history模式默认会请求后端资源?
前端·vue.js·nginx
甜味弥漫1 小时前
《闭包:一个函数偷偷带走了我家的糖》—— 零基础也能懂的JS闭包
前端·javascript
徐安安ye1 小时前
KV Cache的生老病死:FlashAttention里的显存管理全流程
java·服务器·前端
a1117761 小时前
VR看房 网页(开源 threejs)html
前端·开源·html·vr
星星~笑笑1 小时前
vue 超简单 oss分片上传文件 大文件上传阿里云
前端·javascript·vue.js·uni-app
gogoing1 小时前
Claude Code Doc
前端·javascript
烬羽1 小时前
《前端基础实战:从零搭建用户列表,掌握前后端分离核心思想》
前端
lightqjx2 小时前
【前端】前端学习四之JavaScript(Web API -- DOM)
前端·javascript·学习