核心概念
Tailwind 提供给你的 CSS 参考自定义函数和指令。
指令是特定于 Tailwind 的自定义 at-rules,你可以在 CSS 中使用它们,为 Tailwind CSS 项目提供特殊功能。
使用 @import
指令内联导入 CSS 文件,包括 Tailwind 自身:
@import "tailwindcss";
使用 @theme
指令定义项目的自定义设计变量,如字体、颜色和断点:
@theme { --font-display: "Satoshi", "sans-serif"; --breakpoint-3xl: 120rem; --color-avocado-100: oklch(0.99 0 0); --color-avocado-200: oklch(0.98 0.04 113.22); --color-avocado-300: oklch(0.94 0.11 115.03); --color-avocado-400: oklch(0.92 0.19 114.08); --color-avocado-500: oklch(0.84 0.18 117.33); --color-avocado-600: oklch(0.53 0.12 118.34); --ease-fluid: cubic-bezier(0.3, 0, 0, 1); --ease-snappy: cubic-bezier(0.2, 0, 0, 1); /* ... */}
了解更多关于自定义主题的信息,请参阅 主题变量文档。
使用 @source
指令显式指定不被 Tailwind 自动内容检测识别的源文件:
@source "../node_modules/@my-company/ui-lib";
了解更多关于自动内容检测的信息,请参阅 源文件中的类检测文档。
使用 @utility
指令向项目中添加自定义工具类,支持 hover
、focus
和 lg
等变体:
@utility tab-4 { tab-size: 4;}
了解更多关于注册自定义工具类的信息,请参阅 添加自定义工具类文档。
使用 @variant
指令将 Tailwind 变体应用于 CSS 中的样式:
.my-element { background: white; @variant dark { background: black; }}
如果需要同时应用多个变体,可以使用嵌套:
.my-element { background: white; @variant dark { @variant hover { background: black; } }}
了解更多关于变体的信息,请参阅 hover、focus 和其他状态文档。
使用 @custom-variant
指令添加项目中的自定义变体:
@custom-variant pointer-coarse (@media (pointer: coarse));@custom-variant theme-midnight (&:where([data-theme="midnight"] *));
这让你可以像 pointer-coarse:size-48
和 theme-midnight:bg-slate-900
一样书写工具类。
了解更多关于添加自定义变体的信息,请参阅 注册自定义变体文档。
使用 @apply
指令将任何现有的工具类内联到你自己的自定义 CSS 中:
.select2-dropdown { @apply rounded-b-lg shadow-md;}.select2-search { @apply rounded border border-gray-300;}.select2-results__group { @apply text-lg font-bold text-gray-900;}
当你需要编写自定义 CSS(比如覆盖第三方库中的样式)但仍希望使用你的设计变量和保持在 HTML 中使用的相同语法时,这是很有用的。
如果你想在 Vue 或 Svelte 组件的 <style>
块中,或在 CSS 模块中使用 @apply
或 @variant
,你需要导入你的主题变量、自定义工具类和自定义变体,以使这些值在该上下文中可用。
为了在输出中不重复任何 CSS,可以使用 @reference
指令导入你的主样式表作为参考,而不实际包含样式:
<template> <h1>Hello world!</h1></template><style> @reference "../../app.css"; h1 { @apply text-2xl font-bold text-red-500; }</style>
如果你只是使用没有自定义的默认主题,你可以直接导入 tailwindcss
:
<template> <h1>Hello world!</h1></template><style> @reference "tailwindcss"; h1 { @apply text-2xl font-bold text-red-500; }</style>
Tailwind 提供了以下构建时函数,以便更轻松地处理颜色和间距比例。
使用 --alpha()
函数调整颜色的透明度:
.my-element { color: --alpha(var(--color-lime-300) / 50%);}
.my-element { color: color-mix(in oklab, var(--color-lime-300) 50%, transparent);}
使用 --spacing()
函数根据你的主题生成间距值:
.my-element { margin: --spacing(4);}
.my-element { margin: calc(var(--spacing) * 4);}
这在任意值中也很有用,尤其是在与 calc()
结合使用时:
<div class="py-[calc(--spacing(4)-1px)]"> <!-- ... --></div>
以下指令和函数仅为与 Tailwind CSS v3.x 的兼容性而存在。
使用 @config
指令加载一个基于 JavaScript 的旧配置文件:
@config "../../tailwind.config.js";
JavaScript 基于的配置中的 corePlugins
、safelist
和 separator
选项在 v4.0 中不受支持。
使用 @plugin
指令加载一个基于 JavaScript 的旧插件:
@plugin "@tailwindcss/typography";
@plugin
指令接受包名称或本地路径。
使用 theme()
函数通过点符号访问你的 Tailwind 主题值:
.my-element { margin: theme(spacing.12);}
此函数已被弃用,我们建议 使用 CSS 主题变量。