好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

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

<ul>
    <li>
        <a  hr ef=" # " 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-w IT hin 也是一个通过子元素选择父元素的伪类,只不过条件只能是子元素 是否 获取 焦点 , 而 :has 则更灵活和强大。

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

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

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

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

总结

以上是 为你收集整理的 CSS子元素选择父元素的实现 全部内容,希望文章能够帮你解决 CSS子元素选择父元素的实现 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于CSS子元素选择父元素的实现的详细内容...

  阅读:27次