vue中配置scss全局变量的步骤


Posted in Vue.js onDecember 28, 2020

在写项目的过程中,如果用的是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官网中看到此说明。【传送门】

vue中配置scss全局变量的步骤

 

因此,我们需要将配置代码修改成如下样式:

css: {
  loaderOptions: {
    sass: {
      prependData: `@import "~@/styles/_variable.scss";`
    }
  }
}

好了,重启一下项目,大功告成。

以上就是vue中配置scss全局变量的步骤的详细内容,更多关于vue配置scss全局变量的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
vue+vant实现购物车全选和反选功能
Nov 17 Vue.js
解决vue下载后台传过来的乱码流的问题
Dec 05 Vue.js
vue实现防抖的实例代码
Jan 11 Vue.js
vue实现禁止浏览器记住密码功能的示例代码
Feb 03 Vue.js
vue 使用 v-model 双向绑定父子组件的值遇见的问题及解决方案
Mar 01 Vue.js
Vue实现tab导航栏并支持左右滑动功能
Jun 28 Vue.js
Vue监视数据的原理详解
Feb 24 Vue.js
vue cli4中mockjs在dev环境和build环境的配置详情
Apr 06 Vue.js
Vue操作Storage本地化存储
Apr 29 Vue.js
vue中data里面的数据相互使用方式
Jun 05 Vue.js
el-table-column 内容不自动换行的解决方法
Aug 14 Vue.js
Vue Element plus使用方法梳理
Dec 24 Vue.js
为什么推荐使用JSX开发Vue3
Dec 28 #Vue.js
Vue仿百度搜索功能
Dec 28 #Vue.js
vue中watch的用法汇总
Dec 28 #Vue.js
浅析vue中的nextTick
Dec 28 #Vue.js
Vue实现省市区三级联动
Dec 27 #Vue.js
vue3.0自定义指令(drectives)知识点总结
Dec 27 #Vue.js
vue 使用 sortable 实现 el-table 拖拽排序功能
Dec 26 #Vue.js
You might like
oracle资料库函式库
2006/10/09 PHP
实用函数8
2007/11/08 PHP
深入file_get_contents函数抓取内容失败的原因分析
2013/06/25 PHP
WordPress中编写自定义存储字段的相关PHP函数解析
2015/12/25 PHP
PHP遍历目录文件的常用方法小结
2017/02/03 PHP
PHP SPL 被遗落的宝石【SPL应用浅析】
2018/04/20 PHP
PHP call_user_func和call_user_func_array函数的简单理解与应用分析
2019/11/25 PHP
php中使用array_filter()函数过滤数组实例讲解
2021/03/03 PHP
基于jQuery的仿flash的广告轮播代码
2010/11/04 Javascript
ajax处理php返回json数据的实例代码
2013/01/24 Javascript
JS写的贪吃蛇游戏(个人练习)
2013/07/08 Javascript
Bootstrap编写一个兼容主流浏览器的受众门户式风格页面
2016/07/01 Javascript
BootStrap 附加导航组件
2016/07/22 Javascript
DWR3 访问WEB元素的两种方法实例详解
2017/01/03 Javascript
iscroll实现下拉刷新功能
2017/07/18 Javascript
Javascript中的作用域及块级作用域
2017/12/08 Javascript
Webpack实战加载SVG的方法
2017/12/26 Javascript
微信小程序页面间跳转传参方式总结
2019/06/13 Javascript
highcharts.js数据绑定方式代码实例
2019/11/13 Javascript
Python Sql数据库增删改查操作简单封装
2016/04/18 Python
python reduce 函数使用详解
2017/12/05 Python
numpy中的高维数组转置实例
2018/04/17 Python
python处理DICOM并计算三维模型体积
2019/02/26 Python
YUV转为jpg图像的实现
2019/12/09 Python
python opencv图片编码为h264文件的实例
2019/12/12 Python
python批量处理多DNS多域名的nslookup解析实现
2020/06/28 Python
Python自动化测试中yaml文件读取操作
2020/08/20 Python
使用scrapy ImagesPipeline爬取图片资源的示例代码
2020/09/28 Python
贪睡宠物用品:Snoozer Pet Products
2020/02/04 全球购物
计算机应用专业学生的自我评价分享
2013/11/03 职场文书
优秀党务工作者先进事迹材料
2014/12/25 职场文书
地方课程教学计划
2015/01/19 职场文书
员工升职自荐信
2015/03/27 职场文书
电影雨中的树观后感
2015/06/15 职场文书
学习经验交流会总结
2015/11/02 职场文书
十大必看国产动漫排名,魁拔上线,第二曾在日本播出
2022/03/18 国漫