百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

为何说 :has() 选择器是对CSS架构的重塑?

yuyutoo 2025-03-14 22:17 1 浏览 0 评论

家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!

使用 :has() 选择器可以让开发者能够根据子元素来设置父元素的样式,其解决了 CSS 中长期存在的限制,即 无法根据元素内容设置元素样式。

更加直白的说,尽管 CSS 支持根据父元素对子元素进行样式设置,但到目前为止,反向操作还无法实现。而 :has() 选择器为动态、内容感知的样式设置带来了新的可能性。:has() 伪类通过将相对选择器列表作为参数,提供了一种根据参考元素选择父元素或先前兄弟元素的方法。

/* 选择一个 h1 标题,其后跟着一个 p 元素,并将样式应用于 h1*/
h1:has(+ p) {
  margin-bottom: 0;
}

:has() 选择器消除了以前需要使用 JavaScript 或复杂 CSS 的场景,同时与其他用于 检查状态、位置和组合的选择器 结合使用时功能会更加强大:

/* 带有链接的段落样式 */
p:has(a) {
  padding-right: 1.5em;
  background: url(external-link.svg) no-repeat right;
}
/* 表单组中存在无效输入 */
.form-group:has(input:invalid) {
  border-left: 3px solid red;
}
/* h2 标题后紧跟段落 p */
h2:has(+p) {
  margin-bottom: 0.5em;
}

同时,:has() 选择器还可以用于启用响应内容结构的自适应布局:

.grid {
  display: grid;
  gap: 1rem;
}
/* 如果任何卡片内容较长,则切换到单列 */
.grid:has(.card> p:has(+ p)) {
  grid-template-columns: 1fr;
}
/* 当卡片有图像时添加额外的间距 */
.grid:has(.card:has(img)) {
  gap: 2rem;
}

该方法消除了手动管理 class 或 JavaScript 干预以进行布局调整的需要。其从根本上改变了 CSS 架构,即 能够根据子元素对父元素进行样式设置,为常见布局开辟了强大、可维护的方法。

现代浏览器都很好地支持 :has(),并允许生产部署。如果浏览器不支持 :has() 伪类则整个选择器块无效,除非 :has() 位于特殊的选择器列表中,例如: is() 和 :where()。

//  :is() 选择参数列表中选择器可以选择的任何元素
:is(ol, ul) :is(ol, ul) ol {
  list-style-type: lower-greek;
  color: red;
}
//  :where() 选择参数列表可以选择的任何元素
:where(ol, ul) :where(ol, ul) ol {
  list-style-type: lower-greek;
  color: chocolate;
}
 :where() 和 :is() 之间的区别在于 :where() 始终具有 0 特异性,强调的是目标元素选择而非提升优先级,而 :is() 则采用其参数中最具体的选择器特异性。

对于较旧的浏览器,推荐开发者使用打底样式:

/* 基础样式 */
.card {padding: 1rem;}
/* 针对支持 :has() 的浏览器增强样式 */
@supports selector(:has(*)) {
  .card:has(img) { padding: 0; }
}

一个常见的示例是:用 :has() 选择器替换基于 JavaScript 的样式切换(toggle),然后逐渐转向内容感知布局。

参考资料

https://www.trevorlasn.com/blog/has-css-functional-pseudo-class

https://developer.mozilla.org/en-US/docs/Web/CSS/:is

https://developer.mozilla.org/en-US/docs/Web/CSS/:where

https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_cascade/Specificity

https://brackets-hub.com/the-power-of-has-in-css/

https://medium.com/@codeyourthoughts48/css-has-selector-a-brief-overview-8d1ef2c5c656

https://thetechplatform.medium.com/what-is-css-has-selector-38b3aee9fbdf

相关推荐

为何说 :has() 选择器是对CSS架构的重塑?

大家好,很高兴又见面了,我是"...

不得不知的网络安全知识(网络 安全知识)

本文最初发布于BitsandPieces...

从凌晨发布的Manus到3小时复刻的OpenManus

前言2025/3/5凌晨一点半前后,手机里陆续收到一些公众号推文,Manus,LeaveittoManus,感觉一片喧哗,有点Agent里面的Deepseek类似赶脚,索性去注册了,Sorry...

JAVA安全加密通信协议详解(java密码加密哪种方式最安全)

JAVA安全加密通信协议详解在当今这个数字化时代,数据安全变得越来越重要。无论是在企业内部还是互联网上,保护敏感信息免受恶意攻击都是一项至关重要的任务。因此,了解并掌握安全加密通信协议对于每一位开发者...

两篇文章介绍:全新Swift从入门到进阶实战探探iOS APP(完结)

"夏哉ke":quangneng.com/5131/《全新Swift从入门到进阶实战探探iOSAPP》这一课程或书籍主要聚焦于使用Swift语言来开发iOS应用程序,尤其以“探探”这样的社交应用作为...

你写的JSP代码正在拖垮系统90%开发者不知道的过时陷阱与重生法则

"2024年了,我的团队还在用JSP!"某电商平台凌晨崩溃的监控警报,竟源自一行20年前的JSP代码逻辑。这个曾经统治JavaWeb的技术,正在用最隐蔽的方式摧毁你的系统性能......

Java jakarta常用注解详解(java validate注解)

持久化注解JakartaPersistence注解是...

网页出现 403 forbidden 是什么意思?

网页出现403forbidden是什么意思?“403forbidden”是一个HTTP状态码(HTTPSTATUSCODE),它的含义非常好理解。就是:...

孝琳《Queendom2》实力碾压难超越!韩网跪了:其他团来争第2的

记者刘宛欣/综合报导南韩女团竞赛节目《Queendom2》正如火如荼地进行中,日前播出6组人马的第二次竞演,其中以SOLO出击的孝琳继首次竞演拿下满分登冠军宝座后,第二次竞演又毫无悬念满分获得第一,...

《Queendom》排名公开(G)I—DLE夺第一 mamamoo展超强实力位列亚军

人民网讯5日,韩国最新综艺节目《Queendom》播出并公开了竞演排名。在本期节目中,人气女团OHMYGIRL演唱了《秘密花园》,(G)I-DLE将《LATATA》唱出十足底气,Lovelyz则...

React 4、路由库react-router-dom

在React应用中,路由(Routing)是一个关键的功能,它允许用户在不同页面或视图之间导航,而无需重新加载整个页面。React本身并不提供内置的路由功能,但你可以使用第三方库来实现路由。最常...

美人计 | 不管你追哪个团,都去看《Queendom》

以后也别选新的女团了,就让实力与美貌并存的姐姐们神仙打架就挺好。这个综艺8月底开播,最新一期是在十一假期的时候播出,它是Mnet推出的以女团同时回归对决的新概念综艺。参赛的6组都是已出道并且成绩相当不...

理念:无冲突的扩展本地DOM原型(俄乌冲突最新消息)

正如我昨天在博文中指出,我不喜欢使用jQuery的原因之一是因为它的包装对象。对于jQuery来说,这是一个明智的决定:早在2006年它被第一次开发出来的时候,IE有一个非常讨厌的内存泄漏bug,当我...

虚拟DOM真的比操作原生DOM快吗?前端大神提供4个参考观点!收藏

尤雨溪:https://www.zhihu.com/question/31809713/answer/53544875...

DOM丨睡不好伤肾更伤肝真的有证据!

点击蓝字...

取消回复欢迎 发表评论: