- CSS 教程
- CSS - 首页
- CSS - 路线图
- CSS - 简介
- CSS - 语法
- CSS - 选择器
- CSS - 包含
- CSS - 计量单位
- CSS - 颜色
- CSS - 背景
- CSS - 字体
- CSS - 文本
- CSS - 图片
- CSS - 链接
- CSS - 表格
- CSS - 边框
- CSS - 块级边框
- CSS - 内联边框
- CSS - 外边距
- CSS - 列表
- CSS - 内边距
- CSS - 光标
- CSS - 轮廓
- CSS - 尺寸
- CSS - 滚动条
- CSS - 内联块
- CSS - 下拉菜单
- CSS - 可见性
- CSS - 溢出
- CSS - 清除浮动
- CSS - 浮动
- CSS - 箭头
- CSS - 调整大小
- CSS - 引号
- CSS - 顺序
- CSS - 位置
- CSS - 连字符
- CSS - 悬停
- CSS - 显示
- CSS - 聚焦
- CSS - 缩放
- CSS - 平移
- CSS - 高度
- CSS - 连字符字符
- CSS - 宽度
- CSS - 不透明度
- CSS - Z-Index
- CSS - 底部
- CSS - 导航栏
- CSS - 覆盖层
- CSS - 表单
- CSS - 对齐
- CSS - 图标
- CSS - 图片库
- CSS - 注释
- CSS - 加载器
- CSS - 属性选择器
- CSS - 组合器
- CSS - 根元素
- CSS - 盒模型
- CSS - 计数器
- CSS - 剪切
- CSS - 书写模式
- CSS - Unicode-bidi
- CSS - min-content
- CSS - 全部
- CSS - 内嵌
- CSS - 隔离
- CSS - 滚动溢出
- CSS - Justify Items
- CSS - Justify Self
- CSS - Tab Size
- CSS - 指针事件
- CSS - Place Content
- CSS - Place Items
- CSS - Place Self
- CSS - 最大块尺寸
- CSS - 最小块尺寸
- CSS - 混合模式
- CSS - 最大内联尺寸
- CSS - 最小内联尺寸
- CSS - 偏移量
- CSS - 口音颜色
- CSS - 用户选择
- CSS 高级
- CSS - 网格
- CSS - 网格布局
- CSS - Flexbox
- CSS - 可见性
- CSS - 定位
- CSS - 层
- CSS - 伪类
- CSS - 伪元素
- CSS - @规则
- CSS - 文本效果
- CSS - 分页媒体
- CSS - 打印
- CSS - 布局
- CSS - 验证
- CSS - 图片精灵
- CSS - 重要性
- CSS - 数据类型
- CSS3 教程
- CSS3 - 教程
- CSS - 圆角
- CSS - 边框图片
- CSS - 多重背景
- CSS - 颜色
- CSS - 渐变
- CSS - 盒阴影
- CSS - 盒装饰中断
- CSS - 光标颜色
- CSS - 文本阴影
- CSS - 文本
- CSS - 2D 变换
- CSS - 3D 变换
- CSS - 过渡
- CSS - 动画
- CSS - 多列
- CSS - 盒尺寸
- CSS - 工具提示
- CSS - 按钮
- CSS - 分页
- CSS - 变量
- CSS - 媒体查询
- CSS - 函数
- CSS - 数学函数
- CSS - 遮罩
- CSS - 形状
- CSS - 样式图片
- CSS - 特异性
- CSS - 自定义属性
- CSS 响应式
- CSS RWD - 简介
- CSS RWD - 视口
- CSS RWD - 网格视图
- CSS RWD - 媒体查询
- CSS RWD - 图片
- CSS RWD - 视频
- CSS RWD - 框架
- CSS 工具
- CSS - PX 到 EM 转换器
- CSS - 颜色选择器和动画
- CSS 资源
- CSS - 有用资源
- CSS - 讨论
CSS 伪类 - :has()
CSS :has() 伪类根据元素是否包含匹配特定选择器的子元素来表示该元素。
语法
:has(<relative-selector-list>) { /* ... */ }
:has() 伪类不受 Firefox 浏览器支持。
要点
当浏览器不支持 :has() 伪类时,只有在 :has() 用于 :is() 或 :where() 选择器内部时,整个选择器块才会生效。
您不能在另一个 :has() 选择器内部使用 :has() 选择器,因为许多伪元素的存在取决于其父元素的样式。允许您使用 :has() 选择这些伪元素会导致循环查询。
伪元素不能用作 :has() 伪类中的选择器或锚点。
CSS :has() - 相邻兄弟组合器
以下是如何使用 :has() 函数选择所有紧跟在 h3 元素之后的 h2 元素的示例 -
<html> <head> <style> div { background-color: pink; } h2:has(+ h3) { margin: 0 0 50px 0; } </style> </head> <body> <p>You can see it adds bottom margin to h2 elements immediately followed by an h3 element.</p> <div> <h2>Tutorialspoint</h2> <h3>CSS Pseudo-class - :has()</h3> <p>Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.</p> </div> </body> </html>
CSS :has() - 与 :is() 伪类一起使用
CSS 选择器 :is(h1, h2, h3) 选择所有 h1、h2 和 h3 元素。然后,:has() 伪类选择这些元素中任何具有 h2、h3 或 h5 元素作为其下一个兄弟元素的元素,如下所示 -
<html> <head> <style> div { background-color: pink; } :is(h1, h2, h3):has(+ :is(h2, h3, h5)) { margin-bottom: 50px ; } </style> </head> <body> <p>You can see it adds bottom margin to h2 elements immediately followed by an h3 element and h3 element followed by immediately h4.</p> <div> <h2>Tutorialspoint</h2> <h3>CSS Pseudo-class :has()</h3> <h5>with :is() Pseudo-class</h5> <p>Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.</p> </div> </body> </html>
CSS :has() - 逻辑运算
:has(video, audio) 选择器检查元素内部是否存在视频或音频元素。
:has(video):has(audio) 选择器检查元素是否同时包含视频和音频元素。
以下是如何使用 :has() 伪类向 body 元素添加红色边框和 50% 宽度(如果它包含视频或音频元素)的示例 -
<html> <head> <style> video { width: 50%; margin: 50px; } body:has(video, audio) { border: 3px solid red; } </style> </head> <body> <video controls src="images/boat_video.mp4"></video> </body> </html>
正则表达式和 :has() 类比
CSS :has() 选择器和带有前瞻断言的正则表达式在以下方面具有相似性:它们使您能够根据特定模式定位元素(或字符串),而无需实际选择匹配该模式的元素(或字符串)。
特性 | 描述 |
---|---|
正向先行断言 (?=pattern) | CSS 选择器 和正则表达式 abc(?=xyz) 都允许您根据另一个元素紧随其后的情况选择一个元素,而无需实际选择该元素本身。 |
负向先行断言 (?!pattern) | CSS 选择器 .abc:has(+ :not(.xyz)) 类似于正则表达式 abc(?!xyz)。两者仅在 .abc 后面没有 .xyz 时才选择 .abc。 |
广告