常见状态前缀

状态处理概述

Tailwind CSS 通过实用类(utility classes)处理元素的不同状态(如悬停、聚焦、激活等),无需编写自定义 CSS。状态类通过前缀(如 hover:focus:)与基础类结合,实现动态样式。


常见状态前缀

  • 交互状态
    hover: 悬停状态(如 hover:bg-blue-500
    focus: 聚焦状态(如 focus:ring-2
    active: 点击激活状态(如 active:scale-95
    group-hover: 父容器悬停时生效(需配合 group 类)

  • 表单状态
    checked: 复选框/单选选中状态(如 checked:bg-green-500
    disabled: 禁用状态(如 disabled:opacity-50

  • 媒体查询
    sm:md:lg: 等响应式断点前缀(如 md:text-lg


使用示例

悬停与聚焦效果

html 复制代码
<button class="bg-gray-300 hover:bg-blue-500 focus:ring-2 focus:ring-blue-600">
  Click Me
</button>

父容器悬停控制子元素

html 复制代码
<div class="group">
  <div class="text-gray-500 group-hover:text-red-500">Hover over parent</div>
</div>

表单元素状态

html 复制代码
<input type="checkbox" class="checked:bg-green-500 disabled:opacity-30">

自定义状态

通过 @variants 指令扩展自定义状态(需在 Tailwind 配置文件中定义):

css 复制代码
@variants motion-safe {
  .animate-slow {
    animation: spin 3s linear infinite;
  }
}

使用:<div class="motion-safe:animate-slow">


状态叠加顺序

Tailwind 遵循 CSS 层叠规则。多个状态前缀可组合使用,但需注意顺序优先级(如 focus:hover:bg-purple-500 表示聚焦且悬停时的样式)。


注意事项

  1. 启用状态类 :某些状态(如 focus:disabled:)需在 tailwind.config.jsvariants 中显式启用。
  2. 性能优化:避免滥用状态类,尤其是复杂动画或高频交互场景。

通过合理使用状态前缀,可以高效实现动态 UI 效果,减少自定义 CSS 代码量。

相关推荐
兆子龙6 分钟前
从 float 到 Flex/Grid:CSS 左右布局简史与「刁钻」布局怎么搞
前端·架构
YukiMori2311 分钟前
一个有趣的原型继承实验:为什么“男人也会生孩子”?从对象赋值到构造函数继承的完整推演
前端·javascript
_哆啦A梦13 分钟前
Vibe Coding 全栈专业名词清单|设计模式·基础篇(创建型+结构型核心名词)
前端·设计模式·vibecoding
百里静修14 分钟前
一个 Hook 拦截所有 AJAX 请求:ajax-hooker 使用指南与原理
前端
摸鱼的春哥1 小时前
惊!黑客靠AI把墨西哥政府打穿了,海量数据被黑
前端·javascript·后端
小兵张健1 小时前
Playwright MCP 截图标注方案调研(推荐方案1)
前端·javascript·github
小兵张健2 小时前
AI 页面与交互迁移流程参考
前端·ai编程·mcp
小兵张健2 小时前
掘金发布 SOP(Codex + Playwright MCP + Edge)
前端·mcp
小兵张健2 小时前
Mac 上 Antigravity 无法调用 browser_subagent?一次 400 报错排查记录
前端
张拭心3 小时前
编程最强的模型,竟然变成了国产的它
前端·ai编程