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 架构中不可或缺的新利器。

相关推荐
幻影星空VR元宇宙6 小时前
飞行影院设备价格解析及性价比分析
css·百慕大冒险·幻影星空
霍理迪17 小时前
CSS布局方式——定位
前端·css
灯把黑夜烧了一个洞18 小时前
2026年跨年倒计时网页版
javascript·css·html·2026跨年代码·新年代码
铅笔侠_小龙虾18 小时前
html+css 实现键盘
前端·css·html
韩曙亮19 小时前
【Web APIs】移动端返回顶部案例 ( 返回顶部按钮 显示 / 隐藏 设置 | 返回顶部操作 )
前端·javascript·css·html·移动端·web apis·返回顶部
GDAL19 小时前
Tailwind CSS 响应式设计实战指南:从零搭建书签篮自适应页面
前端·css·tailwindcss·书签篮
cz追天之路1 天前
华为机考--- 字符串最后一个单词的长度
javascript·css·华为·less
Light601 天前
CSS逻辑革命:原生if()函数如何重塑我们的样式编写思维
前端·css·响应式设计·组件化开发·css if函数·声明式ui·现代css
前端Hardy1 天前
祝大家 2026 年新年快乐,代码无 bug,需求一次过
javascript·css·html
be or not to be2 天前
HTML+CSS 浮动与表格全总结笔记
css·笔记·html