• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

CSS子元素选择父元素的实现

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

通常一个CSS选择器都是从上往下选择的,通过父元素选择子元素,那么能不能通过子元素选择父元素呢?

<ul>
    <li>
        <a href="#" class="active">1</a>
    </li>
    <li>
        <a href="#">2</a>
    </li>
</ul>

如果我想选择包含 a.active 的 li 该怎么实现呢? 目前我们学到的CSS好像是没有办法的,不过今天要将的一个CSS伪类 :has() 就有这个功能,虽然还处于草案阶段,但是还是可以提前了解一下。

li:has(> a.active){
    color:red;
}

除了表示包含,:has 还可以表示兄弟跟随关系

div:has(+ p){
    color:red;
}

表示选择 <div> 标签,前提是这个div标签必须是被一个<p>紧跟着的。此外还可以与:not 一起使用

article:not(:has(a)){
    color:red;
}

表示不包含 <a> 的 <article>标签。注意这里 :not 和 :has 的先后顺序,不同顺序代表不同的意思

article:has(:not(a)){
    color:red;
}

表示包含非 <a> 的 <article>标签

其实我们前面讲过的 :focus-within 也是一个通过子元素选择父元素的伪类,只不过条件只能是子元素是否获取焦点, 而 :has 则更灵活和强大。

form:focus-within{
    background-color:black;
}

如果通过 :has 实现的话, 可以这样写

form:has(:focus){
    background-color:black;
}

到此这篇关于CSS子元素选择父元素的实现的文章就介绍到这了,更多相关CSS子元素选择父元素内容请搜索极客世界以前的文章或继续浏览下面的相关文章,希望大家以后多多支持极客世界! 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
浅谈CSS 伪元素&amp;伪类的妙用发布时间:2022-06-21
下一篇:
CSS 屏幕大小自适应的实现示例发布时间:2022-06-21
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap