常见状态前缀

状态处理概述

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 代码量。

相关推荐
TheNextByte12 小时前
如何将 Safari 标签转移到新 iPhone 17?
前端·iphone·safari
用户90443816324602 小时前
拒绝 `setInterval`!手撕“死了么”生命倒计时,带你看看 60FPS 下的 Web Worker 优雅多线程
前端·javascript
ttod_qzstudio2 小时前
CSS 样式优先级原则详解:从一个 Vue 组件样式冲突案例说起
前端·css·vue.js
5967851542 小时前
css装饰
前端·css·css3
wearegogog12310 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
Drawing stars10 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
品克缤10 小时前
Element UI MessageBox 增加第三个按钮(DOM Hack 方案)
前端·javascript·vue.js
小二·10 小时前
Python Web 开发进阶实战:性能压测与调优 —— Locust + Prometheus + Grafana 构建高并发可观测系统
前端·python·prometheus
小沐°10 小时前
vue-设置不同环境的打包和运行
前端·javascript·vue.js