:where() 内的选择器优先级被重置为0,不增加整体权重。它用于安全降权,避免覆盖用户样式,不支持伪元素和函数参数,嵌套时仅最外层伪类影响优先级,是语法糖兼权重归零器。
:where() 里的选择器像“隐身”了一样?因为 :where() 确实不增加优先级——它内部所有选择器的权重全被重置为 0。这不是 bug,是设计使然。比如 div :where(.btn, #header),无论 .btn 还是 #header 原本多高权重,进 :where() 后都只算作“普通类/ID”,整个伪类整体贡献 0 优先级增量。
常见错误现象:你写了 #app :where(.primary) { color: red; },却发现被更早定义的 .primary { color: blue; } 覆盖了——不是加载顺序问题,是前者实际优先级跟 .primary 一样(都是 0-1-0),CSS 按后出现者生效。
:where() 适合用来“安全降权”:想用复杂选择器但又怕压过用户自定义样式时,套一层就自动退让::before)、不接受函数参数(不能写 :where(.a:hover)),只接受简单选择器序列:is() 行为相反::is() 取内部最高优先级,:where() 取最低(即 0):where() 和 :is() 混用时优先级怎么算?优先级按“最外层伪类”定,内部嵌套不叠加。例如:
#nav :where(.item, :is(.active, .disabled)) { opacity: 0.8; }
整个选择器优先级 = #nav(1-0-0) + :where()(+0) = 1-0-0;里面 :is(.active, .disabled) 的 ID 级别(比如 .active 是 0-1-0)不会冒出来加成。
立即学习“前端免费学习笔记(深入)”;
:where() 内部写 :is() 没意义:后者升权能力被外层 :where() 直接抹平:where(),再算整体优先级——所以它本质是“语法糖 + 权重归零器”:where() 而不是直接写选择器?当你需要匹配多种结构、又不想干扰现有优先级体系时。:where() 的价值不在“功能增强”,而在“权限克制”。
button :where(svg, img, span) { vertical-align: middle; },确保不会意外压过用户写的 button svg { ... }
:where([data-theme="dark"]) .card 替代 [data-theme="dark"] .card,避免因属性选择器(0-1-0)抬高权重导致难覆盖:where() 包裹,防止其 CSS 泄漏影响宿主页面原生 CSS 支持从 Chrome 105 / Firefox 103 / Safari 15.4 开始,但构建工具常提前处理——这是最容易翻车的地方。
:where(),旧版会把它当无效语法报错或静默删掉postcss-preset-env 默认不降级 :where()(因为它无法被合理降级),开启 stage: 4 也不转译:where() 做关键布局,它不会被 polyfill真正容易被忽略的点:优先级归零不可逆,也没法用 !important 在 :where() 内部“抢救”——那个 !important 作用域仅限于当前声明,不改变选择器本身的权重计算逻辑。