css的父选择器

css的父选择器

首先声明一点,目前没有css的父选择器。新出的css3也没有。但是已经有很多人有很多次提案了。
更新20240126,2023年基本上所有浏览器已经支持

1. 反向选择

在2008年Shaun Inman建议这种父选择器。

a < img{
    border: none;
}

这段css的目的是选择img元素的a标签。

2. parent

Remy Sharp建议使用:parent

a img:parent { background: none; }

3. has

MDN上面已经说明了,has已经处于工作草案阶段。现如今没有一个浏览支持。但是感觉功能相当强大。

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

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

通用选择器是效率最低的CSS选择器,如果有一个父选择器,那么很容易成为低效选择器中的新顶级狗。所以束缚这些想法的最大因素是存在巨大的性能问题。

更新 20240126

目前绝大数浏览器已经支持上面说的has方案。简单写个example

// 表示有子元素div2的div1的宽度为1000px
.div1:has(.div2) {
 	width: 1000px;
}

参考

Parent Selectors in CSS

CSS子元素选择父元素

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值