- Tailwind CSS 教程
- Tailwind CSS - 首页
- Tailwind CSS - 路线图
- Tailwind CSS - 简介
- Tailwind CSS - 安装
- Tailwind CSS - 编辑器设置
- Tailwind CSS - 核心概念
- Tailwind CSS - 实用优先基础
- Tailwind CSS - 悬停、焦点和其他状态
- Tailwind CSS - 响应式设计
- Tailwind CSS - 深色模式
- Tailwind CSS - 重用样式
- Tailwind CSS - 添加自定义样式
- Tailwind CSS - 函数和指令
- Tailwind CSS - 自定义
- Tailwind CSS - 配置
- Tailwind CSS - 内容配置
- Tailwind CSS - 主题配置
- Tailwind CSS - 自定义屏幕
- Tailwind CSS - 自定义颜色
- Tailwind CSS - 自定义间距
- Tailwind CSS - 插件
- Tailwind CSS - 预设
- Tailwind CSS - 基础样式
- Tailwind CSS - 预处理
- Tailwind CSS - 布局
- Tailwind CSS - 宽高比
- Tailwind CSS - 容器
- Tailwind CSS - 列
- Tailwind CSS - 断行之后
- Tailwind CSS - 断行之前
- Tailwind CSS - 断行内部
- Tailwind CSS - 边框装饰断开
- Tailwind CSS - 盒子大小
- Tailwind CSS - 显示
- Tailwind CSS - 浮动
- Tailwind CSS - 清除浮动
- Tailwind CSS - 隔离
- Tailwind CSS - 对象适应
- Tailwind CSS - 对象位置
- Tailwind CSS - 溢出
- Tailwind CSS - 滚动行为
- Tailwind CSS - 位置
- Tailwind CSS - 上/右/下/左
- Tailwind CSS - 可见性
- Tailwind CSS - Z-Index
- Tailwind CSS - Flexbox 和 Grid
- Tailwind CSS - Flex 基准
- Tailwind CSS - Flex 方向
- Tailwind CSS - Flex 换行
- Tailwind CSS - Flex
- Tailwind CSS - Flex 伸展
- Tailwind CSS - Flex 收缩
- Tailwind CSS - 顺序
- Tailwind CSS - 网格模板列
- Tailwind CSS - 网格列起始/结束
- Tailwind CSS - 网格模板行
- Tailwind CSS - 网格行起始/结束
- Tailwind CSS - 网格自动流
- Tailwind CSS - 网格自动列
- Tailwind CSS - 网格自动行
- Tailwind CSS - 间隙
- Tailwind CSS - 内容对齐
- Tailwind CSS - 项目对齐
- Tailwind CSS - 自身对齐
- Tailwind CSS - 内容排列
- Tailwind CSS - 项目排列
- Tailwind CSS - 自身排列
- Tailwind CSS - 位置内容
- Tailwind CSS - 位置项目
- Tailwind CSS - 位置自身
- Tailwind CSS - 间距
- Tailwind CSS - 内边距
- Tailwind CSS - 外边距
- Tailwind CSS - 间距
- Tailwind CSS - 尺寸
- Tailwind CSS - 宽度
- Tailwind CSS - 最小宽度
- Tailwind CSS - 最大宽度
- Tailwind CSS - 高度
- Tailwind CSS - 最小高度
- Tailwind CSS - 最大高度
- Tailwind CSS - 尺寸
- Tailwind CSS - 排版
- Tailwind CSS - 字体系列
- Tailwind CSS - 字体大小
- Tailwind CSS - 字体平滑
- Tailwind CSS - 字体样式
- Tailwind CSS - 字体粗细
- Tailwind CSS - 数字字体变体
- Tailwind CSS - 字间距
- Tailwind CSS - 行高度限制
- Tailwind CSS - 行高
- Tailwind CSS - 列表样式图像
- Tailwind CSS - 列表样式位置
- Tailwind CSS - 列表样式类型
- Tailwind CSS - 文本对齐
- Tailwind CSS - 文本颜色
- Tailwind CSS - 文本装饰
- Tailwind CSS - 文本装饰颜色
- Tailwind CSS - 文本装饰样式
- Tailwind CSS - 文本装饰粗细
- Tailwind CSS - 文本下划线偏移
- Tailwind CSS - 文本转换
- Tailwind CSS - 文本溢出
- Tailwind CSS - 文本换行
- Tailwind CSS - 文本缩进
- Tailwind CSS - 垂直对齐
- Tailwind CSS - 空格
- Tailwind CSS - 断字
- Tailwind CSS - 连字符
- Tailwind CSS - 内容
- Tailwind CSS - 背景
- Tailwind CSS - 背景附件
- Tailwind CSS - 背景剪裁
- Tailwind CSS - 背景颜色
- Tailwind CSS - 背景原点
- Tailwind CSS - 背景位置
- Tailwind CSS - 背景重复
- Tailwind CSS - 背景大小
- Tailwind CSS - 背景图片
- Tailwind CSS - 渐变颜色停止
- Tailwind CSS - 边框
- Tailwind CSS - 边框半径
- Tailwind CSS - 边框宽度
- Tailwind CSS - 边框颜色
- Tailwind CSS - 边框样式
- Tailwind CSS - 分隔线宽度
- Tailwind CSS - 分隔线颜色
- Tailwind CSS - 分隔线样式
- Tailwind CSS - 轮廓宽度
- Tailwind CSS - 轮廓颜色
- Tailwind CSS - 轮廓样式
- Tailwind CSS - 轮廓偏移
- Tailwind CSS - 环宽度
- Tailwind CSS - 环颜色
- Tailwind CSS - 环偏移宽度
- Tailwind CSS - 环偏移颜色
- Tailwind CSS - 效果
- Tailwind CSS - 盒阴影
- Tailwind CSS - 盒阴影颜色
- Tailwind CSS - 不透明度
- Tailwind CSS - 混合模式
- Tailwind CSS - 背景混合模式
- Tailwind CSS - 滤镜
- Tailwind CSS - 模糊
- Tailwind CSS - 亮度
- Tailwind CSS - 对比度
- Tailwind CSS - 投影
- Tailwind CSS - 灰度
- Tailwind CSS - 色相旋转
- Tailwind CSS - 反相
- Tailwind CSS - 饱和度
- Tailwind CSS - 棕褐色
- Tailwind CSS - 背景模糊
- Tailwind CSS - 背景亮度
- Tailwind CSS - 背景对比度
- Tailwind CSS - 背景灰度
- Tailwind CSS - 背景色相旋转
- Tailwind CSS - 背景反相
- Tailwind CSS - 背景不透明度
- Tailwind CSS - 背景饱和度
- Tailwind CSS - 背景棕褐色
- Tailwind CSS - 表格
- Tailwind CSS - 边框折叠
- Tailwind CSS - 边框间距
- Tailwind CSS - 表格布局
- Tailwind CSS - 标题位置
- Tailwind CSS - 过渡和动画
- Tailwind CSS - 过渡属性
- Tailwind CSS - 过渡持续时间
- Tailwind CSS - 过渡时序函数
- Tailwind CSS - 过渡延迟
- Tailwind CSS - 动画
- Tailwind CSS - 变换
- Tailwind CSS - 缩放
- Tailwind CSS - 旋转
- Tailwind CSS - 平移
- Tailwind CSS - 倾斜
- Tailwind CSS - 变换原点
- Tailwind CSS - 交互性
- Tailwind CSS - 重音颜色
- Tailwind CSS - 外观
- Tailwind CSS - 光标
- Tailwind CSS - 光标颜色
- Tailwind CSS - 指针事件
- Tailwind CSS - 调整大小
- Tailwind CSS - 滚动行为
- Tailwind CSS - 滚动边距
- Tailwind CSS - 滚动填充
- Tailwind CSS - 滚动捕捉对齐
- Tailwind CSS - 滚动捕捉停止
- Tailwind CSS - 滚动捕捉类型
- Tailwind CSS - 触摸操作
- Tailwind CSS - 用户选择
- Tailwind CSS - 将更改
- Tailwind CSS - SVG
- Tailwind CSS - 填充
- Tailwind CSS - 描边
- Tailwind CSS - 描边宽度
- Tailwind CSS - 可访问性
- Tailwind CSS - 屏幕阅读器
- Tailwind CSS - 强制颜色调整
- Tailwind CSS - 附加内容
- Tailwind CSS - 与预处理器一起使用
- Tailwind CSS - 生产环境优化
- Tailwind CSS - 参考
- Tailwind CSS - 核心概念
- Tailwind CSS - 自定义
- Tailwind CSS - 布局
- Tailwind CSS - Flexbox 和 Grid
- Tailwind CSS - 间距
- Tailwind CSS - 尺寸
- Tailwind CSS - 排版
- Tailwind CSS - 背景
- Tailwind CSS - 边框
- Tailwind CSS - 效果
- Tailwind CSS - 滤镜
- Tailwind CSS - 表格
- Tailwind CSS - 过渡和动画
- Tailwind CSS - 变换
- Tailwind CSS - 交互性
- Tailwind CSS - 资源
- Tailwind CSS - 讨论
- Tailwind CSS - 有用资源
Tailwind CSS - 与预处理器一起使用
预处理器是一种扩展 CSS 并编译成常规 CSS 语法的脚本语言,以便 Web 浏览器可以读取。
由于 Tailwind 是 PostCSS 插件,因此您可以使用 SASS、LESS 和 Stylus 等预处理器,但是使用它们有一些技巧。如果您已经了解这些预处理器的几种语法,那么它们可能无法像在常规 CSS 中那样与 Tailwind 一起使用。有关指南,请阅读本文。
为了获得最佳的开发体验,我们强烈建议您使用 PostCSS 插件,并且不要使用 Sass 或 Less 预处理器。
使用 PostCSS 作为预处理器
如果您正在一个新项目上工作,并且不需要将其与任何现有的 Sass/Less/Stylus 样式表集成,那么PostCSS 是推荐与 Tailwind CSS 一起使用的预处理器,您应该认真考虑依赖其他 PostCSS 插件来添加您使用的预处理器功能,而不是使用单独的预处理器。
- 构建速度更快:由于您的 CSS 不必由多个工具进行解析和处理,因此仅使用 PostCSS 即可更快地编译您的 CSS。
- 没有怪癖或变通方法:因为 Tailwind 向 CSS 添加了一些新的非标准关键字(例如 @tailwind、@apply、theme() 等),所以您经常必须以烦人且不直观的方式编写 CSS,才能使预处理器获得预期的输出。 专门使用 PostCSS 可以避免这种情况。
构建时导入
预处理器提供的最有用功能之一是能够将 CSS 组织成多个文件,并通过预先处理 @import 语句而不是在浏览器中将其组合在构建时。要安装 PostCSS,请运行以下命令。
npm install -D postcss-import
然后将其作为第一个插件添加到您的 PostCSS 配置中
// postcss.config.js module.exports = { plugins: { 'postcss-import': {}, tailwindcss: {}, autoprefixer: {}, } }
'postcss-import' 非常严格,不允许在文件顶端以外的任何地方使用'@import' 语句。
不起作用,@import 语句必须放在最前面/* components.css */ .btn { padding: theme('spacing.4') theme('spacing.2'); /* ... */ } /* Will not work */ @import "./components/card";为导入和实际 CSS 使用单独的文件
/* components.css */ @import "./components/buttons.css"; @import "./components/card.css";
/* components/buttons.css */ .btn { padding: theme('spacing.4') theme('spacing.2'); /* ... */ }
/* components/card.css */ .card { padding: theme('spacing.4'); /* ... */ }
嵌套
我们建议使用我们捆绑的tailwindcss/nesting插件,这是一个PostCSS插件,它封装了postcss-nested或postcss-nesting,并作为兼容性层,以确保您首选的嵌套插件能够正确理解Tailwind的独特语法,从而提供对嵌套声明的支持。
tailwindcss包已经包含了它,因此您只需将其添加到您的PostCSS设置中,放在Tailwind之前即可使用。
// postcss.config.js module.exports = { plugins: { 'postcss-import': {}, 'tailwindcss/nesting': {}, tailwindcss: {}, autoprefixer: {}, } }
在底层,它默认使用postcss-nested插件,该插件为Tailwind CSS插件API中的嵌套支持提供支持,并且语法类似于SASS。
如果您更愿意使用postcss-nesting,请先安装该插件。
npm install -D postcss-nesting
然后在您的PostCSS配置中将插件本身作为参数传递给tailwindcss/nesting。
// postcss.config.js module.exports = { plugins: { 'postcss-import': {}, 'tailwindcss/nesting': 'postcss-nesting', tailwindcss: {}, autoprefixer: {}, } }
如果您想使用特定版本的postcss-nested并想覆盖我们与tailwindcss/nesting本身捆绑在一起的版本。
如果您正在使用postcss-preset-env,则应禁用嵌套功能,并让tailwindcss/nesting为您处理。
// postcss.config.js module.exports = { plugins: { 'postcss-import': {}, 'tailwindcss/nesting': 'postcss-nesting', tailwindcss: {}, 'postcss-preset-env': { features: { 'nesting-rules': false }, }, } }
变量
由于CSS支持变量,因此根本不需要使用预处理器来使用变量。要了解更多关于CSS变量的信息。
:root { --theme-color: #52b3d0; } /* ... */ .btn { background-color: var(--theme-color); /* ... */ }
使用的变量可以用Tailwind的'theme()'函数替换。这使您可以直接在CSS中访问来自tailwind.config.js文件的全部设计令牌。
.btn { background-color: theme('colors.blue.500'); padding: theme('spacing.2') theme('spacing.4'); /* ... */ }
厂商前缀
Autoprefixer将帮助您管理CSS中的厂商前缀。
/* install it via npm */ npm install -D autoprefixer /* Add it to the very end of your plugin list in your PostCSS configuration */ module.exports = { plugins: { tailwindcss: {}, autoprefixer: {}, } }
安装Tailwind作为PostCSS插件
在安装PostCSS插件之前,您应该安装Tailwind CSS。
先决条件
要安装PostCSS,请按照以下步骤操作。
步骤1:将Tailwind添加到您的PostCSS配置中
/* postcss.config.js */ module.exports = { plugins: { tailwindcss: {}, autoprefixer: {}, } }
步骤2:配置您的模板路径
步骤3:将Tailwind指令添加到您的CSS中
/* tailwind.config.js */ /** @type {import('tailwindcss').Config} */ module.exports = { content: ["./src/**/*.{html,js}"], theme: { extend: {}, }, plugins: [], }
步骤4:启动您的构建过程
@tailwind base; @tailwind components; @tailwind utilities;
步骤5:开始在您的HTML中使用Tailwind
npm run dev