使用 Sass 作为 CSS 预处理器,基于 sass-loader 实现。
你可以通过如下的命令安装插件:
你可以在 rsbuild.config.ts
文件中注册插件:
注册插件后,你可以在代码中引入 *.scss
,*.sass
,*.module.scss
或 *.module.sass
文件,无须添加其他配置。
如果你需要自定义 Sass 的编译行为,可以使用以下配置项。
修改 sass-loader 的配置。
Object | Function
当 sassLoaderOptions
的值是一个对象时,它会与默认配置通过 Object.assign
进行浅层合并,值得注意的是,sassOptions
会通过 deepMerge 进行深层合并。
当 sassLoaderOptions
的值是一个函数时,默认配置作为第一个参数传入,你可以直接修改配置对象,也可以返回一个值作为最终结果:
/\.s(?:a|c)ss$/
>= 1.1.0
用于指定一部分 .scss
或 .sass
模块,这些模块会被 sass-loader
编译。这个值与 Rspack 中的 rule.test
选项相同。
比如:
undefined
用于排除一部分 .sass
或 .scss
模块,这些模块不会被 sass-loader
编译。
比如:
boolean
true
>= 1.2.0
是否使用 resolve-url-loader 来重写 URL。
当启用时,resolve-url-loader
允许你在 Sass 文件中写相对路径的 URL,这些 URL 会被正确地从当前 Sass 文件的位置解析,而不是相对于 Sass 入口文件(例如 main.scss
)。
如果设置为 false
,构建性能会得到提升,但 Rsbuild 会使用 Sass 的原生 URL 解析,这意味着所有 URL 必须相对于 Sass 入口文件。
Sass 提供了多种实现,包括 sass、sass-embedded 和 node-sass。
Rsbuild 默认使用最新的 sass-embedded
实现。sass-embedded
是一个围绕原生 Dart Sass 可执行文件的 JavaScript wrapper,具备一致的 API 和最佳的性能。
如果你需要使用其他 Sass 实现,而不是使用 Rsbuild 内置的 sass-embedded
,可以在项目中安装需要使用的 Sass 实现,并通过 sass-loader
的 implementation 选项来设置。
将 sass-embedded
修改为其他 Sass 实现,可能会构建性能显著下降。
Rsbuild 默认使用最新的 modern-compiler
API,如果你依赖了 Sass 的 legacy
API,可以将 sass-loader 的 api 选项设置为 legacy
,以兼容一些废弃的 Sass 写法。
Sass 的 legacy
API 已经被废弃,并且将在 Sass 2.0 中被移除,建议迁移到 modern-compiler
API,详见 Sass - Legacy JS API。
Sass 会通过 warning 日志提示你一些废弃的写法,这些写法在 Sass 未来的大版本中将会被移除,建议根据日志进行修改。如果你不想看到这些日志,可以通过 Sass 的 silenceDeprecations 选项来忽略这些警告。
例如,@import
已经被 Sass 废弃,当你使用该语法时,Sass 会输出如下日志:
@rsbuild/plugin-sass
默认添加了如下配置来忽略 @import
的警告,如果你需要忽略其他废弃警告,可以使用同样的方式。
请查看 Sass Deprecations 了解更多信息。
通过使用 include
和 exclude
选项,你可以同时注册多个 Sass 插件,并为每个插件指定不同的选项。
例如: