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 相关文章推荐
深入了解Vue3模板编译原理
Nov 19 Vue.js
vue3.0中setup使用(两种用法)
Dec 02 Vue.js
详解如何在vue+element-ui的项目中封装dialog组件
Dec 11 Vue.js
jenkins自动构建发布vue项目的方法步骤
Jan 04 Vue.js
vue+echarts实现中国地图流动效果(步骤详解)
Jan 27 Vue.js
聊聊vue 中的v-on参数问题
Jan 29 Vue.js
vue使用echarts画组织结构图
Feb 06 Vue.js
VUE实现吸底按钮
Mar 04 Vue.js
一文带你理解vue创建一个后台管理系统流程(Vue+Element)
May 18 Vue.js
Vue实现动态查询规则生成组件
May 27 Vue.js
vue如何使用模拟的json数据查看效果
Mar 31 Vue.js
vue3 自定义图片放大器效果的示例代码
Jul 23 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
phpfans留言版用到的数据操作类和分页类
2007/01/04 PHP
利用PHP实现短域名互转
2013/07/05 PHP
PHP.vs.JAVA
2016/04/29 PHP
深入理解PHP 数组之count 函数
2016/06/13 PHP
从数据结构分析看:用for each...in 比 for...in 要快些
2013/04/17 Javascript
js中的for如何实现foreach中的遍历
2014/05/31 Javascript
ECMAScript6函数默认参数
2015/06/12 Javascript
JavaScript中Function函数与Object对象的关系
2015/12/17 Javascript
三种AngularJS中获取数据源的方式
2016/02/02 Javascript
jQuery新窗口打开外链接
2016/07/21 Javascript
第一次接触神奇的Bootstrap表单
2016/07/27 Javascript
JS图片左右无缝隙滚动的实现(兼容IE,Firefox 遵循W3C标准)
2016/09/23 Javascript
用headjs来管理和加载js 提高网站加载速度
2016/11/29 Javascript
angular中实现控制器之间传递参数的方式
2017/04/24 Javascript
为你的微信小程序体积瘦身详解
2017/05/20 Javascript
JS中的多态实例详解
2017/10/15 Javascript
javaScript canvas实现(画笔大小 颜色 橡皮的实例)
2017/11/28 Javascript
vscode配置vue下的es6规范自动格式化详解
2019/03/20 Javascript
jQuery对底部导航进行跳转并高亮显示的实例代码
2019/04/23 jQuery
Layui给switch添加响应事件的例子
2019/09/03 Javascript
解决$store.getters调用不执行的问题
2019/11/08 Javascript
[02:50]【扭转乾坤,只此一招】DOTA2永雾林渊版本开启新篇章
2020/12/22 DOTA
Python greenlet实现原理和使用示例
2014/09/24 Python
JSONLINT:python的json数据验证库实例解析
2017/11/28 Python
Python编程argparse入门浅析
2018/02/07 Python
Python 找到列表中满足某些条件的元素方法
2018/06/26 Python
python字典的setdefault的巧妙用法
2019/08/07 Python
莫斯科制造商的廉价皮大衣:Fursk
2020/06/09 全球购物
2014道德模范事迹材料
2014/02/16 职场文书
园林系毕业生求职信
2014/06/23 职场文书
家装业务员岗位职责
2015/04/03 职场文书
2019暑假学生安全口号
2019/06/27 职场文书
Ajax是什么?Ajax高级用法之Axios技术
2021/04/21 Javascript
关于python类SortedList详解
2021/09/04 Python
Elasticsearch 索引操作和增删改查
2022/04/19 Python
Python FuzzyWuzzy实现模糊匹配
2022/04/28 Python