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

所属分类: 网页制作 / CSS 阅读数: 1365
收藏 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实现微信小程序仿QQ顶部提示弹框动画效果

这篇文章主要介绍了纯CSS实现微信小程序仿QQ顶部提示弹框动画效果,需要的朋友可以参考下
收藏 0 赞 0 分享

使用CSS实现无滚动条滚动的两种方法

这篇文章主要介绍了使用CSS实现无滚动条滚动的两种方法,需要的朋友可以参考下
收藏 0 赞 0 分享

深入浅析CSS 选择器分组

这篇文章主要介绍了CSS 选择器分组的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

css 评分效果的星星示例

这篇文章主要介绍了css 评分效果的星星示例的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

CSS3实现文本垂直排列的方法

这篇文章主要介绍了CSS3实现文本垂直排列的方法,也就是运用了CSS的writing-mode属性,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

利用CSS3实现文字折纸效果实例代码

这篇文章主要给大家介绍了关于利用CSS3实现文字折纸效果的相关资料,文中给出了完整的示例代码,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

通过css使用background-color为背景图添加遮罩效果的两种方法

这篇文章主要介绍了通过css使用background-color为背景图添加遮罩效果的两种方法,需要的朋友可以参考下
收藏 0 赞 0 分享

css遮罩全屏居中对齐的实现方式

本文通过实例代码给大家介绍了css遮罩全屏居中对齐的实现方式,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
收藏 0 赞 0 分享

HTML+CSS实现下拉菜单的实现

这篇文章主要介绍了HTML+CSS实现下拉菜单的实现的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

CSS中的导航栏和下拉菜单的实现

这篇文章主要介绍了CSS中的导航栏和下拉菜单的实现的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多