1. 核心概念
  2. 函数与指令

核心概念

函数和指令

Tailwind 提供给你的 CSS 参考自定义函数和指令。

指令

指令是特定于 Tailwind 的自定义 at-rules,你可以在 CSS 中使用它们,为 Tailwind CSS 项目提供特殊功能。

@import

使用 @import 指令内联导入 CSS 文件,包括 Tailwind 自身:

CSS
@import "tailwindcss";

@theme

使用 @theme 指令定义项目的自定义设计变量,如字体、颜色和断点:

CSS
@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

使用 @source 指令显式指定不被 Tailwind 自动内容检测识别的源文件:

CSS
@source "../node_modules/@my-company/ui-lib";

了解更多关于自动内容检测的信息,请参阅 源文件中的类检测文档

@utility

使用 @utility 指令向项目中添加自定义工具类,支持 hoverfocuslg 等变体:

CSS
@utility tab-4 {
tab-size: 4;
}

了解更多关于注册自定义工具类的信息,请参阅 添加自定义工具类文档

@variant

使用 @variant 指令将 Tailwind 变体应用于 CSS 中的样式:

CSS
.my-element {
background: white;
@variant dark {
background: black;
}
}

如果需要同时应用多个变体,可以使用嵌套:

CSS
.my-element {
background: white;
@variant dark {
@variant hover {
background: black;
}
}
}

了解更多关于变体的信息,请参阅 hover、focus 和其他状态文档

@custom-variant

使用 @custom-variant 指令添加项目中的自定义变体:

CSS
@custom-variant pointer-coarse (@media (pointer: coarse));
@custom-variant theme-midnight (&:where([data-theme="midnight"] *));

这让你可以像 pointer-coarse:size-48theme-midnight:bg-slate-900 一样书写工具类。

了解更多关于添加自定义变体的信息,请参阅 注册自定义变体文档

@apply

使用 @apply 指令将任何现有的工具类内联到你自己的自定义 CSS 中:

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 中使用的相同语法时,这是很有用的。

@reference

如果你想在 Vue 或 Svelte 组件的 <style> 块中,或在 CSS 模块中使用 @apply@variant,你需要导入你的主题变量、自定义工具类和自定义变体,以使这些值在该上下文中可用。

为了在输出中不重复任何 CSS,可以使用 @reference 指令导入你的主样式表作为参考,而不实际包含样式:

Vue
<template>
<h1>Hello world!</h1>
</template>
<style>
@reference "../../app.css";
h1 {
@apply text-2xl font-bold text-red-500;
}
</style>

如果你只是使用没有自定义的默认主题,你可以直接导入 tailwindcss

Vue
<template>
<h1>Hello world!</h1>
</template>
<style>
@reference "tailwindcss";
h1 {
@apply text-2xl font-bold text-red-500;
}
</style>

函数

Tailwind 提供了以下构建时函数,以便更轻松地处理颜色和间距比例。

--alpha()

使用 --alpha() 函数调整颜色的透明度:

Input CSS
.my-element {
color: --alpha(var(--color-lime-300) / 50%);
}
Compiled CSS
.my-element {
color: color-mix(in oklab, var(--color-lime-300) 50%, transparent);
}

--spacing()

使用 --spacing() 函数根据你的主题生成间距值:

Input CSS
.my-element {
margin: --spacing(4);
}
Compiled CSS
.my-element {
margin: calc(var(--spacing) * 4);
}

这在任意值中也很有用,尤其是在与 calc() 结合使用时:

HTML
<div class="py-[calc(--spacing(4)-1px)]">
<!-- ... -->
</div>

兼容性

以下指令和函数仅为与 Tailwind CSS v3.x 的兼容性而存在。

@config

使用 @config 指令加载一个基于 JavaScript 的旧配置文件:

CSS
@config "../../tailwind.config.js";

JavaScript 基于的配置中的 corePluginssafelistseparator 选项在 v4.0 中不受支持。

@plugin

使用 @plugin 指令加载一个基于 JavaScript 的旧插件:

CSS
@plugin "@tailwindcss/typography";

@plugin 指令接受包名称或本地路径。

theme()

使用 theme() 函数通过点符号访问你的 Tailwind 主题值:

CSS
.my-element {
margin: theme(spacing.12);
}

此函数已被弃用,我们建议 使用 CSS 主题变量