css 文件可以直接引入到main.js中,scss文件如果没有scss特殊语法也可以直接引入index.js,只有scss文件中的特殊语法全局引入的时候无法显示,所以需要特殊处理
样式文件目录:
在项目中新建了样式文件,分别又创建了三个文件夹
common.scss
:是清除默认样式和公共class的文件index.scss
:统一修改项目中公共样式的文件scssFile.scss
:是全局所用到的scss
特殊语法的文件,声明变量,mixin
等等
因为main.js
可以直接import css文件,而不可以直接import scss文件, common.scss
和 index.scss
虽然后缀名是scss
,但是样式中是没有scss特殊语法的,所以直接引入到main.js
中即可全局生效
import "@/style/common.scss";
import "@/style/index.scss";
而scssFile.scss
中的特殊语法在main.js中引入并不会起效果,所以需要每个文件都要引入一下,后期优化会变得维护比较麻烦,我们可以利用sass-loader
的特性,可以将一段代码插入在每个scss
文件的头部
下载依赖:
yarn add node-sass --save-dev
yarn add sass-loader --save-dev
或者
npm install node-sass --save-dev
npm install sass-loader --save-dev
将以下代码添加到vue.config.js
配置文件中:
css: {
loaderOptions: {
sass: {
data: `@import "@/style/scssFile.scss";`
}
}
}
因为这种方法是在每个scss文件头部都引入了
scssFile.scss
文件,如果这个文件中有以下格式的代码(普通样式编写),那么这个文件将会重复渲染,假如引入到了10个vue
文件中,那么下面这行样式就会被渲染10次,.border { border: 1px solid #333; }