CSS逻辑组合伪类

CSS 的逻辑组合伪类有 4 种,分别是::not()、:is()、:where()和:has()。

否定伪类:not()

否定伪类,是在元素与括号里面的参数不匹配的时候,就会对这个伪类进行匹配。比如::not(span):{color:red},这就会匹配不是 span 元素的其他所有元素,包括 html 和 body。

否定伪类:not()的几个特点:

  1. :not()的优先级是 0,因为它的优先级是由括号里面的参数来定的;
  2. :not()伪类可以同时判断多个选择器,比如input:not(:disabled):not(:read-only) {}​​,表示匹配不属于禁用状态同时也不处于只读状态的 input 元素;
  3. not()支持多个表达式,比如:.cs-li:not(li, dd) {}​​,还有另外一种写法:.cs-li:not(li):not(dd) {}​​。但是这两种写法,要考虑兼容性问题;
  4. :not()也支持选择符,比如:input:not(.a > .b) { border: red solid; }​​;

:is()

:is()伪类,是把括号里面的选择都分配出去。语法如下:

复制代码
:is(article) p {}
:is(article, section) p {}
:is(.article[class], section) p {}
.some-class:is(article:not([id]), section) p {}​​

is 这个伪类最大的作用,就是在简化选择器。比如我们要设置多个 div 内的图片样式,样式代码如下:

复制代码
.div-a > img,
.div-b > img,
.div-c > img,
.div-d > img {
   display: block;
   width: 100%; height: 100%;
   border-radius: 50%;
}​​

通过 is 伪类来简化一下:

复制代码
:is(.div-a,.div-b,.div-c,.div-d)>img{
   display: block;
   width: 100%; height: 100%;
   border-radius: 50%;
}

:where()伪类的功能和 is 是一样的,只是它的优先级一直都是 0,会忽略括号内参数的优先级。比如::where(.article, section) p {}​​的优先级就是 p 标签的优先级。

关联伪类:has()

has()伪类,就是匹配某个选择器。例如:a:has(span) { color:red }​​,a 元素内的 span 标签的字体颜色设置为 red。

这就是 CSS 经常遇到的几个逻辑伪类。

相关推荐
一天 24h2 分钟前
从单体到分布式:JWT 如何彻底改变 Web 认证系统
前端·分布式
持梦远方2 分钟前
Nginx 静态资源挂载与前端部署实战笔记
linux·前端·笔记·nginx
木斯佳3 分钟前
前端八股文面经大全:腾讯云智前端一面(2026-05-13)·面经深度解析
前端·状态模式
fanzhonghong4 分钟前
javaWeb后端开发之Linux项目部署3和Docker部署1
linux·服务器·前端·docker
拉里呱唧5 分钟前
在线可视化HTML编辑器横评:8款拖拽式工具的实测对比
前端·编辑器·html
lihaozecq8 分钟前
Agent 开发 Todo 机制设计,让 Agent 拥有规划能力
前端·agent·ai编程
lchcy17 分钟前
移动端h5好多兼容性问题啊
前端
KaMeidebaby23 分钟前
卡梅德生物技术快报|多肽库筛选:基于全质粒 PCR 的噬菌体文库构建与小分子表位淘选实战
前端·数据库·其他·百度·新浪微博
m0_5027249526 分钟前
vue3生成pdf
前端·javascript·vue.js·pdf
@不误正业27 分钟前
2026-05-16-多Agent协作框架深度实战-从ReAct到Plan-and-Execute全架构演进
前端·react.js·架构