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

所属分类: 网页制作 / CSS 阅读数: 1346
收藏 0 赞 0 分享

通常一个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子元素选择父元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家! 

更多精彩内容其他人还在看

兼容浏览器的css网页细线表格设计

细线表格如果单纯设置边框,很难保证浏览器兼容。
收藏 0 赞 0 分享

FORM 不换行的方法

在写 Html 的时, 写到 FORM 会让造成空隔多空一行 等等的问题。
收藏 0 赞 0 分享

如何使div垂直水平居中的css代码

很多人都会遇到这样的问题:如何使DIV居中,div垂直居中,div水平居中.
收藏 0 赞 0 分享

左侧固定宽度,右侧自适应宽度的CSS布局

这个是我练习做网页查资料查到的,有很多不错的布局。将其总结,并写上自己使用的一些感悟。
收藏 0 赞 0 分享

黑客选择CSS代码挂马 CSS挂马攻防实录

随着Web2.0的普及,各种网页特效用得越来越多,这也给黑客一个可乘之机。他们发现,用来制作网页特效的CSS代码,也可以用来挂马。而比较讽刺的是,CSS挂马方式其实是从防范E挂马的CSS代码演变而来。
收藏 0 赞 0 分享

IE6下CSS定义DIV高度的问题

IE6下默认的字体尺寸大致在 12 – 14px 之间,当你试图定义一个高度小于这个默认值的 div 的时候, IE 会固执的认为这个层的高度不应该小于字体的行高。
收藏 0 赞 0 分享

CSS网页实例 利用box-sizing实现div仿框架结构实现代码

利用box-sizing实现div仿框架.需要的朋友可以参考下。
收藏 0 赞 0 分享

CSS样式表与HTML网页的关系分析

浅谈CSS样式表和html文档的关系.
收藏 0 赞 0 分享

CSS样式表中继承关系的空格与不空格

CSS样式表空格与不空格的关系
收藏 0 赞 0 分享

规范HTML代码可以节省修改代码的时间

css技巧 清除多余的标签让代码更加有意义.
收藏 0 赞 0 分享
查看更多