vue中配置scss全局变量的步骤
在写项目的过程中,如果用的是scss来编写样式代码,常常需要定义各种变量,例如主题色、主字号之类的,因此我们会把这些变量写到一个单独的_variable.scss文件内,但是每次都要在vue单文件内引入这些变量未免太繁琐了,所以有没有办法可以默认把变量文件作为全局文件进行引入呢?答案是肯定的,可以用下面的方法进行配置,可以根据当前使用的框架和环境来进行方法的选择。
一、使用vue-cli(即vue-cli2)脚手架时
1. 首先,需要安装一个loader,sass-resources-loader
npm install sass-resources-loader --save-dev
2. 找到build文件夹下的utils.js文件,在文件内找到这段配置代码
return {
css: generateLoaders(),
postcss: generateLoaders(),
less: generateLoaders('less'),
sass: generateLoaders('sass', { indentedSyntax: true }),
scss: generateLoaders('sass'),
stylus: generateLoaders('stylus'),
styl: generateLoaders('stylus')
}
3. 修改其中的scss项,改为
scss: generateLoaders('sass').concat({
loader:'sass-resources-loader',
options:{
resources:path.resolve(__dirname,'../src/styles/_variable.scss')
}
})
4. 重启项目,即可在其他文件内使用这些变量文件了
二、使用@vue/cli(即vue-cli3)脚手架时
1. 找到vue.config.js文件,如果没有的话,则自己在根目录新建一个即可
2. 在文件内编写如下代码:
module.exports = {
css: {
loaderOptions: {
sass: {
data: `@import "@/styles/_variable.scss";`
}
}
}
}
3. 重启项目,即可使用
注意:如果编写完以上代码,重启项目后出现这个错误:
Invalid options object. Sass Loader has been initialised using an options object that does not match the API schema.
那么说明,你安装的sass-loader应该是V8的版本,可以在package.json中查看是否确实如此,如果的确是v8版本以上,则需要配置不同的写法,因为在V8中已经废除了data这个配置项,改为了prependData,具体可以在vue cli官网中看到此说明。【传送门】

因此,我们需要将配置代码修改成如下样式:
css: {
loaderOptions: {
sass: {
prependData: `@import "~@/styles/_variable.scss";`
}
}
}
好了,重启一下项目,大功告成。
以上就是vue中配置scss全局变量的步骤的详细内容,更多关于vue配置scss全局变量的资料请关注脚本之家其它相关文章!
相关文章
Vue中的el-date-picker时间选择器的使用实例详解
el-date-picker是Element UI框架中提供的日期选择器组件,它支持单个日期、日期范围、时间、日期时间等多种选择方式,本文给大家介绍Vue中的el-date-picker时间选择器的使用,感兴趣的朋友一起看看吧2023-10-10
解决vue项目中遇到 Cannot find module ‘chalk‘ 报错的问题
这篇文章主要介绍了解决vue项目中遇到 Cannot find module ‘chalk‘ 报错的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-11-11
vue中使用pdfjs-dist + turnjs实现页面的翻书浏览功能
这篇文章主要介绍了vue中使用pdfjs-dist + turnjs实现页面的翻书浏览,通过本文学习我们知道了pdfjs-dist 的工作原理是把获取到的 pbf 的文件的数据流, 利用 canvas转换成图片,本文通过实例代码详解讲解,需要的朋友可以参考下2022-10-10
vue3组合API中setup、 ref、reactive的使用大全
本文给大家介绍vue3组合API中setup、 ref、reactive的用法,初步了解reactive的使用及具体用法,通过示例代码给大家介绍的非常详细,需要的朋友参考下吧2021-06-06


最新评论