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 相关文章推荐
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 Vue.js
vuex的数据渲染与修改浅析
Nov 26 Vue.js
基于Vue3.0开发轻量级手机端弹框组件V3Popup的场景分析
Dec 30 Vue.js
Vue 实例中使用$refs的注意事项
Jan 29 Vue.js
vue浏览器返回监听的具体步骤
Feb 03 Vue.js
vue3.0 自适应不同分辨率电脑的操作
Feb 06 Vue.js
详解Vue的options
May 15 Vue.js
深入理解Vue的数据响应式
May 15 Vue.js
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
Jun 09 Vue.js
idea编译器vue缩进报错问题场景分析
Jul 04 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
Vue组件更新数据v-model不生效的解决
Apr 02 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
用PHPdig打造属于你自己的Google[图文教程]
2007/02/14 PHP
PHP结合Jquery和ajax实现瀑布流特效
2016/01/07 PHP
Javascript的时间戳和php的时间戳转换注意事项
2013/04/12 Javascript
node.js中的buffer.write方法使用说明
2014/12/10 Javascript
根据配置文件加载js依赖模块
2014/12/29 Javascript
jQuery中on()方法用法实例
2015/01/19 Javascript
js仿QQ中对联系人向左滑动、滑出删除按钮的操作
2016/04/07 Javascript
基于jQuery倒计时插件实现团购秒杀效果
2016/05/13 Javascript
逻辑表达式中与或非的用法详解
2016/06/06 Javascript
jQuery中ajax错误调试分析
2016/12/01 Javascript
原生JS仿QQ阅读点击展开、收起效果
2017/03/08 Javascript
JS中的三个循环小结
2017/06/20 Javascript
nodejs实现爬取网站图片功能
2017/12/14 NodeJs
vue项目开发中setTimeout等定时器的管理问题
2018/09/13 Javascript
vue 在methods中调用mounted的实现操作
2020/08/07 Javascript
Javascript 模拟mvc实现点餐程序案例详解
2020/12/24 Javascript
[02:57]DOTA2亚洲邀请赛 SECRET战队出场宣传片
2015/02/07 DOTA
python实现微信防撤回神器
2019/04/29 Python
解决pandas展示数据输出时列名不能对齐的问题
2019/11/18 Python
解决Python命令行下退格,删除,方向键乱码(亲测有效)
2020/01/16 Python
python 读取二进制 显示图片案例
2020/04/24 Python
中专自荐信
2013/10/13 职场文书
入党转预备思想汇报
2014/01/07 职场文书
财务工作者先进事迹材料
2014/01/17 职场文书
小学毕业感言150字
2014/02/05 职场文书
2014年安全生产责任书
2014/07/22 职场文书
2014年教育工作总结
2014/11/26 职场文书
出纳岗位职责
2015/01/31 职场文书
离婚被告答辩状
2015/05/22 职场文书
三严三实学习心得体会(精选N篇)
2016/01/05 职场文书
2016大学生暑期社会实践心得体会
2016/01/14 职场文书
初二物理教学反思
2016/02/19 职场文书
2016年师德先进个人事迹材料
2016/02/29 职场文书
Python数据可视化之绘制柱状图和条形图
2021/05/25 Python
深入理解go slice结构
2021/09/15 Golang
Nginx 安装SSL证书完成HTTPS部署
2022/04/28 Servers