解决 webpack 配置 sass-loader后报错,无法正常build

news/2024/12/21 19:36:20/

1. 问题描述

  1. 总是打包build报错,本质上css样式语法也没写错
  2. 在使用 sass-resources-loader 的项目中,开发者常常遇到构建错误或意外的样式行为,这是因为
    sass-resources-loader 的作用和使用场景并不总是被正确理解。sass-resources-loader
    主要用于全局注入 Sass 变量 和 混入,而不适合直接包含实际的 CSS 样式规则。如果 scss
    文件中混入了普通样式定义,可能会导致构建失败或样式重复应用等问题。

常见问题场景:

开发者尝试通过 sass-resources-loader 全局引入的 scss 文件中直接包含 CSS 样式。
variables.scss 和 global.scss 文件中定义了具体的选择器和样式规则,而这些文件应该只包含 Sass
变量、混入和函数等工具类样式。 项目构建时出现错误,如 Expected digit 或 Unexpected token 等。

2. 原因分析

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;
}

3. 解决方案

为了解决这个问题,需要遵循以下原则:

  1. 确保全局注入的 SCSS 文件只包含工具类样式
    variables.scss 和 global.scss 文件中应仅包含 Sass 变量、混入(mixin) 和 函数,而不要包含实际的 CSS 样式规则。
    示例:正确的工具类 SCSS 文件
// 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'),],},},],},],},
};

http://www.ppmy.cn/news/1526582.html

相关文章

静态和动态类型语言

动态类型语言和静态类型语言 1、动态类型语言 动态类型语言和动态语言是完全不同的两个概念。 动态类型语言:是指在运行期间才去做数据类型检查的语言,说的是数据类型, 动态语言:说的是运行是改变结构,说的是代码结…

requests-html的具体使用方法有哪些?

‌requests-html是一个功能强大的Python库,用于发送HTTP请求和解析HTML内容。它的使用方法包括安装库、基本使用、发送带有参数的请求、图片抓取实战案例、解析网页内容、执行JavaScript代码、使用CSS选择器来查找元素、继续跟踪链接并获取内容等。‌ ‌安装request…

mysql笔记5(列属性完整性)

文章目录 1. 列属性问题① not null② default③ auto_increment 2. 主键(Primary Key)① 作用② 好处③ 特点④ 设置主键建表时后期添加 ⑤ 查看主键⑥ 删除主键⑦ 注意 3. 组合键(复合键)① 设置复合主键建表时后期添加 ② 删除复合主键③ 复合主键的作用④ 复合主键的弊端 4…

??Ansible——ad-hoc

文章目录 一、ad-hoc介绍二、ad-hoc的使用1、语法2、ad-hoc常用模块1)shell模块2)command模块3)script模块4)file模块5)copy模块6)yum模块7)yum-repository模块8)service模块9&#…

【2024最新版】Java JDK安装配置全攻略:图文详解

目录 1. 引言2. 准备工作2.1 **确定操作系统**2.2 **检查系统要求**2.3 **下载JDK安装包**3. 安装步骤(以Windows系统为例)4. 配置环境变量4.1 jdk配置验证4.2 **配置JAVA_HOME环境变量**4.3 **配置Path环境变量**4.4 验证jdk是否配置成功 5. 结语 1. 引…

修改docker的默认存储位置及镜像存储位置

前言 Docker 默认安装的情况下,会使用 /var/lib/docker/ 目录作为存储目录,用以存放拉取的镜像和创建的容器等。 不过由于此目录一般都位于系统盘,遇到系统盘比较小,而镜像和容器多了后就容易出问题,这里说明一下如何修…

Vue 生命周期与 TypeScript:深入理解组件生命周期

Vue 生命周期与 TypeScript:深入理解组件生命周期 引言 Vue.js 作为一种流行的前端框架,其组件生命周期是开发过程中不可或缺的一部分。理解并正确利用Vue的生命周期,可以帮助开发者构建更加健壮和可维护的应用。而当TypeScript与Vue结合使…

从头开始学Spring—06初识声明式事务

目录 1.概念 1.1编程式事务 1.2声明式事务 2.JdbcTemplate 2.1准备工作 2.1.1加入依赖 2.1.2创建jdbc.properties 2.1.3配置Spring的配置文件 2.2测试 2.2.1在测试类装配JdbcTemplate 2.2.2测试增删改功能 2.2.3查询一条数据为实体类对象 2.2.4查询多条数据为一个…