当前位置: 首页 > news >正文

vue中引入sass、scss

常规步骤

1. 创建项目

使用vue cli 脚手架工具创建项目

vue create xxxx

2. 创建全局样式文件

全局样式变量
路径:@/assets/styles/variables.scss

//flex 布局变量
$--flex-direction: ("row", "column");
$--flex-position: ("start", "center", "end");

布局样式类
路径:@/assets/styles/layout.scss


@each $direction in $--flex-direction {.flex-#{$direction} {display: flex;flex-direction: #{$direction};}@each $p1 in $--flex-position {@each $p2 in $--flex-position {.flex-#{$direction}-#{$p1}-#{$p2} {display: flex;flex-direction: #{$direction};@if $p1!=center {justify-content: flex-#{$p1};} @else {justify-content: #{$p1};}@if $p2!=center {align-items: flex-#{$p2};} @else {align-items: #{$p2};}}}}
}

3. 创建全局公用样式文件

全局共用样式
路径:@/assets/styles/main.scss

@import "@/assets/styles/layout.scss";div {@extend .flex-row;
}

4. 引入全局公用样式

在App.vue或者main.js中映入均可

<template><router-view />
</template><style lang="scss">
@import "@/assets/styles/main.scss";body {margin: 0;padding: 0;border: none;outline: none;
}
#app {position: absolute;top: 0;left: 0;width: 100%;height: 100%;font-family: 微软雅黑;color: #000000;
}
</style>

5. 配置全局样式类文件

在vue.config.js中配置全局样式类,具体配置方法可以参考vue cli官方文档

const { defineConfig } = require("@vue/cli-service");
module.exports = defineConfig({transpileDependencies: true,css: {loaderOptions: {scss: {additionalData: `@import "~@/assets/styles/variables.scss","~@/assets/styles/layout.scss";`}}}
});

FAQ

1. 样式被多次重复编译

在这里插入图片描述

原因

  1. 产生的原因是因为在vue.config.js中通过@import指令导入了SCSS样式文件`,并且在vue组件库内或者全局样式内再次引入,导致样式类被多次重复编译

  2. vue.config.js是vue编译的入口文件,所以vue在编译时会先加载vue.config.js内配置的SCSS文件,而通过@import指令导入的文件,scss-loader会在编译后将已经编译的全局样式变量、样式类、带入到后续scss文件的编译中

解决方法

  1. 去掉多余的引用文件

例如以下代码,在main.scss中引入了layout.scss文件,而layout.scss文件已经在vue.config.js中配置了载入,所以这里无需再引入

@import "@/assets/styles/layout.scss";div {@extend .flex-row;
}
  1. 使用@use指令导入文件,避免文件被多次编译
@use "@/assets/styles/layout.scss" as *;div {@extend .flex-row;
}
  1. vue.config.js只配置工具性样式文件,如果全局变量文件、全局样式类文件;不要引入非工具性样式文件,例如全局组件样式、main.scss等。所以同理在App.vue文件中只引入非工具性样式文件,因为如果在App.vue文件中引入工具性样式文件不生效的,因为vue项目中,只有在vue.config.js中配置的样式文件,才会被编译到每个vue组件样式内

如以下代码,同样会产生多次重复编译

const { defineConfig } = require("@vue/cli-service");
module.exports = defineConfig({transpileDependencies: true,css: {loaderOptions: {scss: {additionalData: `@import "~@/assets/styles/main.scss";`}}}
});

2. 样式类、变量名找不到

在这里插入图片描述

原因

  1. 原因1:scss-loader在编译scss时,是根据从上到下,从前到后的顺序编译,如果文件内的类名不在scss-loader的堆栈内时,就会抛出以上错误
  2. 原因2:@use导入的文件只对当前文件上下文有效,不会成为全局属性

解决方法

  1. 原因1:检查引入scss文件的顺序是否正确

例如如下代码:当variables.scss文件位于layout.scss文件后时,在编译layout.scss时就会抛出变量不存在错误,因为此时scss-loader的堆栈中没有对应的变量

const { defineConfig } = require("@vue/cli-service");
module.exports = defineConfig({transpileDependencies: true,css: {loaderOptions: {scss: {additionalData: `@import "~@/assets/styles/layout.scss","~@/assets/styles/variables.scss";`}}}
});
  1. 原因2:
  • 如果报错位置是在scss文件中:需要检查对应的文件是否被引入,如果没有引入,需要引入对应的文件
  • 如果报错位置是在vue组件内,需要查看vue.config.js的配置中是否引入了对应的文件

3. @use rules must be written before any other rules.

原因

  1. 原因1:被引用文件内存在使用@use指令导入,而引用文件通过@import指令导入被引用文件;因为@use指令不能和其他指令混合
  2. 原因2:@use指令写在了 @import指令后

解决方法

  1. 问题1:所以在引用文件内使用@use ‘xxxxx’ as * 作为导入语法
@use '~@/xxx/xxx' as *;
  1. 问题2:所有的@use指令必须放在最前面
@use '~@/xxx/xxx' as *;
@import '~@/xxx/xx';

4. Private members can’t be accessed from outside their modules.

原因

  1. 问题产生原因是,当使用@use导入文件后,因为被应用文件在声明变量或方法时在方法时,在变量名或方法名前添加了-或者_,导致变量或方法成为了当前模块 的私有变量或私有方法
  2. 通过@use方法导入的文件,都会被sass认为是一个单独的模块,每个模块之间是相互独立的,所以要想使用某个模块属性,就必须是非私有属性,这也就是为什么,@use可以避免样式被重复编译,因为每个模块只会编译一次

解决方法

  1. 去掉非私有属性前的-_

相关文章:

  • mysql B+树索引
  • 第1周:Day 3 - PyTorch与TensorFlow的异同介绍(入门级)
  • cookie和session的工作过程和作用:弥补http无状态的不足
  • 数据结构——单链表上基本操作的实现
  • Docker(七)使用网络
  • 力扣第236题——二叉树的最近公共祖先 (C语言题解)
  • shell编程-3
  • [Python] scikit-learn之mean_squared_error函数(Mean Squared Error(MSE))介绍和使用案例
  • 设计模式——观察者模式
  • Python进程池multiprocessing.Pool
  • Spring第七天(AOP)
  • Red Hat Enterprise Linux 9.3 安装图解
  • docker 使用 vcs/2018 Verdi等 eda 软件
  • python爬虫案例分享
  • 力扣每日一练(24-1-18)
  • [LeetCode] Wiggle Sort
  • Android路由框架AnnoRouter:使用Java接口来定义路由跳转
  • JavaScript类型识别
  • Javascript设计模式学习之Observer(观察者)模式
  • JSONP原理
  • JS题目及答案整理
  • Material Design
  • MySQL数据库运维之数据恢复
  • nodejs实现webservice问题总结
  • Python_OOP
  • ⭐ Unity 开发bug —— 打包后shader失效或者bug (我这里用Shader做两张图片的合并发现了问题)
  • 精益 React 学习指南 (Lean React)- 1.5 React 与 DOM
  • 那些被忽略的 JavaScript 数组方法细节
  • 实现菜单下拉伸展折叠效果demo
  • 消息队列系列二(IOT中消息队列的应用)
  • 主流的CSS水平和垂直居中技术大全
  • ​LeetCode解法汇总2304. 网格中的最小路径代价
  • ​猴子吃桃问题:每天都吃了前一天剩下的一半多一个。
  • # 手柄编程_北通阿修罗3动手评:一款兼具功能、操控性的电竞手柄
  • #{}和${}的区别?
  • #define MODIFY_REG(REG, CLEARMASK, SETMASK)
  • #FPGA(基础知识)
  • (C语言)strcpy与strcpy详解,与模拟实现
  • (js)循环条件满足时终止循环
  • (pojstep1.3.1)1017(构造法模拟)
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (转)可以带来幸福的一本书
  • .NET Micro Framework初体验(二)
  • .NET多线程执行函数
  • .net中生成excel后调整宽度
  • /使用匿名内部类来复写Handler当中的handlerMessage()方法
  • [ CTF ]【天格】战队WriteUp- 2022年第三届“网鼎杯”网络安全大赛(青龙组)
  • [ 攻防演练演示篇 ] 利用通达OA 文件上传漏洞上传webshell获取主机权限
  • [ 环境搭建篇 ] 安装 java 环境并配置环境变量(附 JDK1.8 安装包)
  • [8-23]知识梳理:文件系统、Bash基础特性、目录管理、文件管理、文本查看编辑处理...
  • [AIGC] 开源流程引擎哪个好,如何选型?
  • [Android] 修改设备访问权限
  • [C++ 从入门到精通] 12.重载运算符、赋值运算符重载、析构函数
  • [DP 训练] Longest Run on a Snowboard, UVa 10285
  • [EFI]英特尔 冥王峡谷 NUC8i7HVK 电脑 Hackintosh 黑苹果efi引导文件