常见问题场景:
开发者尝试通过 sass-resources-loader 全局引入的 scss 文件中直接包含 CSS 样式。
variables.scss 和 global.scss 文件中定义了具体的选择器和样式规则,而这些文件应该只包含 Sass
变量、混入和函数等工具类样式。 项目构建时出现错误,如 Expected digit 或 Unexpected token 等。
sass-resources-loader 主要用于将 Sass 变量、混入(mixin) 和 函数 等工具类样式注入到每个 scss 文件的作用域中。其作用相当于在每个 scss 文件中隐式地 @import 一次这些工具文件。这意味着 sass-resources-loader 不会将实际的样式插入到每个 scss 文件中,而是仅仅将变量和混入等工具类代码注入。
因此,sass-resources-loader 的适用范围仅限于工具类样式。如果你在全局引入的 scss 文件中包含普通的 CSS 样式(如选择器和样式定义),这些样式会被反复注入到每个 scss 文件中,导致不必要的重复和冲突。
// variables.scss
$primary-color: #333;
$font-size: 16px;
// 错误:普通的 CSS 选择器和样式不应放在这里
body {
font-family: Arial, sans-serif;
color: $primary-color;
}
为了解决这个问题,需要遵循以下原则:
// variables.scss
$primary-color: #333;
$font-size-base: 16px;
// mixins.scss
@mixin flex-center {
display: flex;
justify-content: center;
align-items: center;
}
```javascript
// webpack.config.js
const path = require('path');
module.exports = {
module: {
rules: [
{
test: /\.scss$/,
use: [
'style-loader',
'css-loader',
'sass-loader',
{
loader: 'sass-resources-loader',
options: {
// 仅注入工具类文件,不包括普通样式
resources: [
path.resolve(__dirname, 'src/styles/variables.scss'),
path.resolve(__dirname, 'src/styles/mixins.scss'),
],
},
},
],
},
],
},
};