使用 Tailwind CSS

Tailwind CSS 是一个以 Utility Class 为基础的 CSS 框架和设计系统,可以快速地为组件添加常用样式,同时支持主题样式的灵活扩展。

你可以通过 PostCSS 插件来在 Rsbuild 中接入 Tailwind CSS。

安装 Tailwind CSS

由于 Rsbuild 内置支持了 postcssautoprefixer,你只需要安装 tailwindcss,无须安装其他 npm 包:

npm

yarn

pnpm

bun

  1. npm add tailwindcss -D

配置 PostCSS

你可以通过 postcss.config.cjstools.postcss 来注册 tailwindcss 的 PostCSS 插件。

postcss.config.cjs

  1. module.exports = {
  2. plugins: {
  3. tailwindcss: {},
  4. },
  5. };

TIP

Rsbuild 内置了 autoprefixer,因此你只需要注册 tailwindcss 插件。

配置 Tailwind CSS

在当前项目的根目录创建 tailwind.config.js 文件,并添加以下内容:

tailwind.config.js

  1. /** @type {import('tailwindcss').Config} */
  2. module.exports = {
  3. content: ['./src/**/*.{html,js,ts,jsx,tsx}'],
  4. theme: {
  5. extend: {},
  6. },
  7. plugins: [],
  8. };

TIP

上述配置仅供参考,你可以根据项目需要进行调整,比如非 TypeScript 项目不需要包含 ts 和 tsx 文件。

需要注意的是,content 选项应包含所有用到 Tailwind 类名的源文件的路径。详情可参考 tailwindcss - Content 配置

tailwind.config.js

  1. /** @type {import('tailwindcss').Config} */
  2. module.exports = {
  3. content: [
  4. './src/**/*.{html,js,ts,jsx,tsx}',
  5. '../../lib1/src/**/*.{js,ts,jsx,tsx}',
  6. ],
  7. theme: {
  8. extend: {},
  9. },
  10. plugins: [],
  11. };

其他配置方式

  • 你可以在 postcss.config.cjs 中直接传入 Tailwind CSS 的配置:

postcss.config.cjs

  1. module.exports = {
  2. plugins: {
  3. tailwindcss: {
  4. content: ['./src/**/*.{html,js,ts,jsx,tsx}'],
  5. // ...other options
  6. },
  7. },
  8. };
  • 也可以通过 tools.postcss 来设置 Tailwind CSS 的配置:

rsbuild.config.js

  1. import tailwindcss from 'tailwindcss';
  2. export default {
  3. tools: {
  4. postcss: {
  5. plugins: [
  6. tailwindcss({
  7. content: ['./src/**/*.{html,js,ts,jsx,tsx}'],
  8. // ...other options
  9. }),
  10. ],
  11. },
  12. },
  13. };

但我们建议将 Tailwind CSS 的配置放在 tailwind.config.* 中,因为其他方式可能会导致 Tailwind CSS 的构建性能劣化,参考 tailwindcss/issues/14229

引入 CSS

在 CSS 入口文件中添加 @tailwind 指令:

main.css

  1. @tailwind base;
  2. @tailwind components;
  3. @tailwind utilities;

根据需求不同,你可以选择性地导入 Tailwind CSS 提供的 CSS 样式。请参考 @tailwind 文档 来了解 @tailwind 指令的详细用法。

完成

你已经完成了在 Rsbuild 中接入 Tailwind CSS 的全部步骤!

你可以在任意组件或 HTML 中使用 Tailwind 的 utility classes,比如:

  1. <h1 class="text-3xl font-bold underline">Hello world!</h1>

更多用法请参考 Tailwind CSS 文档

VS Code 插件

Tailwind CSS 提供了 Tailwind CSS IntelliSense 插件,用于在 VS Code 中自动补全 Tailwind CSS 的 class names、CSS functions 和 directives。

你可以在 VS Code 中安装该插件,即可开启自动补全功能。

构建性能

在使用 Tailwind CSS 时,如果没有正确地配置 tailwind.config.js 中的 content 字段,可能会导致构建性能和热更新性能下降。这是因为 Tailwind CSS 内部会基于 content 定义的 glob 来匹配文件,扫描的文件数量越多,产生的性能开销越大。

因此,我们建议精确地指定需要扫描的路径,以避免不必要的性能开销。例如,仅包括项目源码中实际包含 Tailwind 类名的 HTML 或 JS 文件,避免包含不相关的文件或目录,尤其是 node_modules 目录。

下面是一个扫描 node_modules 的错误示例:

tailwind.config.js

  1. /** @type {import('tailwindcss').Config} */
  2. module.exports = {
  3. content: [
  4. './src/**/*.{html,js,ts,jsx,tsx}',
  5. // 扫描大量文件,导致性能下降
  6. './node_modules/**/*.js',
  7. ],
  8. };

优化样式体积

如果你需要优化 Tailwind CSS 的样式体积,欢迎尝试 rsbuild-plugin-tailwindcss

该插件读取了 Rspack 的模块图信息,自动设置准确的 content 配置,以生成尽可能少的 Tailwind CSS 样式。

rsbuild.config.ts

  1. import { pluginTailwindCSS } from 'rsbuild-plugin-tailwindcss';
  2. export default {
  3. plugins: [pluginTailwindCSS()],
  4. };

参考 rsbuild-plugin-tailwindcss 了解更多。