0

0

CSS伪类:is()嵌套在Sass/Less等预处理器中的写法对比

P粉602998670

P粉602998670

发布时间:2026-03-09 08:16:01

|

435人浏览过

|

来源于php中文网

原创

预处理器需版本适配和配置调整才能支持 :is():sass v1.33+ 识别,旧版报错;less v4.1+ 需关闭严格模式;均推荐用插值 #{} 或顶层书写规避解析问题。

css伪类:is()嵌套在sass/less等预处理器中的写法对比

直接写 :is() 会报错,预处理器默认不解析

Sass 和 Less 默认把 :is() 当成普通伪类字符串处理,但实际它属于 CSS 原生语法,需要浏览器运行时解析。预处理器在编译阶段若遇到未识别的伪类(比如 :is():has()),可能直接抛错,或更隐蔽地——悄悄删掉整个选择器、甚至整条规则。

  • Less v4.1+ 支持原样输出 :is(),但需关闭严格模式(strictMath: false 不相关,关键是别用 javascriptEnabled 干预选择器)
  • Sass(Dart Sass)v1.33+ 才开始识别 :is(),旧版(如 Node Sass)完全不认,会报 Invalid CSS after "...": expected "{", was ":is("
  • 如果用 @extend%placeholder 引用了含 :is() 的选择器,Sass 旧版本会直接崩溃

Sass 中安全写法:用插值 #{} 绕过解析

不是所有地方都能直接敲 :is(),尤其当它嵌套在 & 或与其他伪类混用时。最稳的方式是用插值强制“逃逸”预处理器解析逻辑,让内容原样透出到 CSS。

  • ✅ 正确:&:hover, #{':is(ul, ol) li'}:focus { color: blue; }
  • ❌ 错误:&:hover, :is(ul, ol) li:focus { ... }(旧 Sass 报错;新 Sass 虽能编译,但嵌套层级可能错乱)
  • ⚠️ 注意:#{} 内不能有变量插值(如 #{':is(#{$list}, p) li'}),否则 Sass 会提前求值导致语法错误
  • 性能无影响——插值只是字符串拼接,不增加运行时开销

Less 中写 :is() 要关掉选择器校验

Less 默认会对选择器结构做轻量校验,遇到 :is() 这类新语法容易误判为非法。不改配置的话,常见现象是整条规则消失、无报错、无输出。

Colossyan
Colossyan

AI虚拟人出镜视频生成

下载
  • 必须在编译配置里加 math: 'always'(非必需)但关键是设 strictUnits: false 并确保没启用 javascriptEnabled
  • ✅ 推荐写法:.menu:hover, :is(nav, header) .logo { opacity: 1; }(Less v4.2+ 直接支持)
  • ❌ 避免嵌套写法:.box { &:is(:hover, :active) { ... } } —— Less 不支持伪类作为 & 后缀
  • 兼容性提示:即使 Less 编译成功,也要确认目标浏览器是否支持 :is()(Chrome 105+/Firefox 103+/Safari 15.4+)

真正麻烦的是和 @media@container 嵌套混用

预处理器对媒体查询内嵌套的支持本就参差不齐,再叠一层 :is(),很容易触发解析边界问题。这不是写法对错问题,而是当前工具链的解析深度限制。

立即学习前端免费学习笔记(深入)”;

  • Sass 在 @media (min-width: 768px) { :is(button, a):focus { ... } } 中通常没问题,但换成 @container (min-width: 400px) { ... } 就可能失败(Dart Sass v1.70+ 才初步支持)
  • Less 对 @container 根本无感知,会直接忽略整个块——此时 :is() 即使写对也白搭
  • 最保险的退路:把含 :is() 的规则抽到顶层,用注释标记来源,避免嵌套

预处理器对 :is() 的支持不是“开了就全好”,而是按版本、按上下文、按嵌套深度分层生效。你看到的“能编译”,不等于“能正确生成目标选择器”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1051

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

830

2023.11.06

Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.10.12

Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.10.12

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

739

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1564

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

59

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 41.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号