推荐使用 .card :is(h1, p, .meta) 替代重复前缀,语义清晰且复用性强;需避免嵌套:is()、伪元素及不支持的选择器,并为旧浏览器提供兼容性回退。用 :is() 替代长串重复前缀选择器当多个选择器共享同一父级路径(比如 .card h1、.card p、.card .meta),硬写三遍 .card 不仅冗余,还容易漏改、难定位。直接用 :is() 把后半段"变体"括起来就行。常见错误是把整个选择器塞进去却忘了保留共用部分:写成 :is(.card h1, .card p, .card .meta) 没问题,但写成 .card :is(h1, p, .meta) 语义就变了------后者匹配的是「所有在 .card 内的 h1/p/.meta」,而前者严格限定为「以 .card 开头的那三条规则」。实际项目中多数情况要的是后者写法。.card :is(h1, p, .meta) → 推荐,语义清晰,复用性强:is(.card h1, .card p, .card .meta) → 可行,但修改父选择器时得全量替换避免嵌套 :is(:is(...)),目前 Safari 15.4+ 才稳定支持多层,旧版会直接失效:is() 的参数里能写哪些东西它接受任意简单选择器或组合选择器,包括类名、标签、属性选择器、伪类,甚至 :not() ------但不能包含伪元素(::before)或需要运行时计算的选择器(如 :has(),目前仅 Chrome 105+ 支持且不稳定)。典型误用是试图在 :is() 里塞 :hover 单独使用:.btn :is(:hover, :focus) 是错的,因为 :hover 必须依附于某个元素;正确写法是 .btn:is(:hover, :focus),让伪类直接作用于 .btn。立即学习"前端免费学习笔记(深入)";允许::is([disabled], [readonly])、:is(.error, .warning, .success)、:is(a[href^="https"], a[href^="tel"]) 禁止::is(::before)、:is(:has(> img))(兼容性差)、:is(* + *)(相邻兄弟选择器不被支持)注意空格:.list :is(li, .item) 匹配后代,.list:is(li, .item) 会报语法错误------冒号前不能有空格IE 和老版 Safari 下怎么处理 :is() 回退它不支持渐进增强式回退(不像 @supports 可包裹整条规则),浏览器遇到不认识的 :is() 会直接丢弃整条 CSS 规则。所以不能只靠它做关键样式。 arXiv Xplorer ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。
相关推荐
2301_815279522 小时前
如何用 flatMap 清理数组中的无效数据并同步转换格式草莓熊Lotso2 小时前
Linux 线程同步与互斥(一):彻底搞懂线程互斥原理、互斥量底层实现与 RAII 封装2301_764150562 小时前
CSS如何为目标锚点设置高亮样式_使用-target伪类定位当前模块qq_342295822 小时前
HTML支持变量吗_与JavaScript数据绑定方式【解答】2301_813599552 小时前
如何使用Python查询MongoDB并转为Pandas DataFrame_数据分析集成实战21439652 小时前
如何通过SSH隧道连接远程数据库_本地端口转发与phpMyAdminChuer_2 小时前
详解智能问数的增效逻辑,全方位拆解智能问数实战场景2401_883600252 小时前
required属性如何触发验证_必填字段检查机制【方法】callJJ2 小时前
JVM 内存区域划分详解——从生活比喻到运行时数据区全景图