CSS `:has()` 实战指南:让 CSS 拥有“if 逻辑”

🔮 CSS :has() 实战指南:让 CSS 拥有"if 逻辑"

你是否经常写这样的 JS:

js 复制代码
if (element.querySelector('input:checked')) {
  element.classList.add('active');
}

现在,只需要用 :has(),你就能让 CSS 自己完成判断。


🧠 什么是 :has()

:has() 是一个关系伪类选择器,允许你根据子元素或后代元素的状态,来影响父元素的样式。

基本语法

css 复制代码
.parent:has(.child) {
  background: lightyellow;
}

📌 含有 .child.parent 会被选中。


✅ 实战一:表单错误状态

html 复制代码
<div class="form-item">
  <input type="text" required>
  <span class="error">必填项</span>
</div>
css 复制代码
.form-item:has(input:invalid) {
  border: 1px solid red;
}

.form-item:has(input:valid) {
  border: 1px solid green;
}

✅ 父容器会根据 input 的校验状态自动改变样式,无需 JS。


🧪 实战二:卡片 Hover 触发内部内容变化

html 复制代码
<div class="card">
  <button>操作</button>
</div>
css 复制代码
.card:has(:hover) {
  box-shadow: 0 2px 10px rgba(0,0,0,0.15);
}

📌 当 .card 内任何子元素 hover 时,整个卡片都会响应。


🧪 实战三:替代 JS 的下拉菜单展开

html 复制代码
<nav class="menu">
  <details>
    <summary>更多选项</summary>
    <ul>
      <li>设置</li>
      <li>帮助</li>
    </ul>
  </details>
</nav>
css 复制代码
.menu:has(details[open]) {
  background: #f0f9ff;
}

✅ 当 <details> 展开时,父级菜单会自动改变背景,完全不需要写 JS。


🌟 高级技巧

  1. 与否定逻辑结合

    css 复制代码
    .list:has(:not(li)) {
      background: #fee2e2; /* 如果列表为空,标记 */
    }
  2. 与交互伪类结合

    css 复制代码
    .card:has(button:focus) {
      outline: 2px solid blue;
    }
  3. 条件式布局控制

    css 复制代码
    .grid:has(.wide) {
      grid-template-columns: 2fr 1fr;
    }

🌐 浏览器支持(2025)

浏览器 支持情况
Chrome 105+
Edge 105+
Safari 15.4+
Firefox ⚠️ 实验支持(需开启 flag)

📌 大多数现代浏览器已经支持,Firefox 也即将跟进。


⚠️ 注意事项

  • 过度使用 :has() 可能带来性能问题(因为需要浏览器反向查询 DOM)
  • 尽量用在 UI 交互和组件样式上,而不是大规模列表匹配
  • Firefox 用户需注意兼容性,可提供 JS fallback

✨ 一句话总结

:has() 是让 CSS 更加"智能"的关键一步,它让样式具备逻辑判断能力,能大幅减少 JS 样式控制逻辑,是现代 CSS 架构中不可或缺的新利器。

相关推荐
苏打水com1 小时前
第十二篇:Day34-36 前端工程化进阶——从“单人开发”到“团队协作”(对标职场“大型项目协作”需求)
前端·javascript·css·vue.js·html
软件技术NINI2 小时前
盒模型在实际项目中有哪些应用场景?
前端·css·html
苏打水com5 小时前
第十篇:Day28-30 工程化优化与部署——从“能跑”到“好用”(对标职场“项目上线”需求)
前端·css·vue·html·js
用户6600676685396 小时前
纯 CSS 复刻星战开场:让文字在宇宙中滚动
前端·css
李少兄6 小时前
前端开发中的多列布局(Multi-column Layout)
前端·css
苏打水com7 小时前
第十一篇:Day31-33 前端安全与性能监控——从“能用”到“安全可靠”(对标职场“系统稳定性”需求)
前端·javascript·css·vue.js·html
syt_10137 小时前
grid布局之-子项放置1
前端·javascript·css
syt_10138 小时前
grid布局之-子项放置2
前端·javascript·css
Youyzq18 小时前
前端项目发布到cdn上css被编译失效问题rgba失效和rgb失效
前端·css·算法·cdn
茄汁面1 天前
实现紧贴边框的高亮流光动画效果(长方形适配)
前端·javascript·css