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+Element实现增删改查的示例源码
Nov 23 Vue.js
在vue中动态修改css其中一个属性值操作
Dec 07 Vue.js
vue 通过base64实现图片下载功能
Dec 19 Vue.js
vue实现购物车的小练习
Dec 21 Vue.js
Vue+scss白天和夜间模式切换功能的实现方法
Jan 05 Vue.js
Vue 集成 PDF.js 实现 PDF 预览和添加水印的步骤
Jan 22 Vue.js
解决vue项目本地启动时无法携带cookie的问题
Feb 06 Vue.js
vue如何实现关闭对话框后刷新列表
Apr 08 Vue.js
vue动态绑定style样式
Apr 20 Vue.js
如何vue使用el-table遍历循环表头和表体数据
Apr 26 Vue.js
Vue Mint UI mt-swipe的使用方式
Jun 05 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
PHP学习笔记之三 数据库基本操作
2011/01/17 PHP
php获取字段名示例分享
2014/03/03 PHP
windows的文件系统机制引发的PHP路径爆破问题分析
2014/07/28 PHP
PHP中使用localhost连接Mysql不成功的解决方法
2014/08/20 PHP
php提交post数组参数实例分析
2015/12/17 PHP
PHP几个实用自定义函数小结
2016/01/25 PHP
thinkPHP5框架闭包函数与子查询传参用法示例
2018/08/02 PHP
PHP中__set()实例用法和基础讲解
2019/07/23 PHP
看了就知道什么是JSON
2007/12/09 Javascript
第一个JavaScript入门基础 document.write输出
2010/02/22 Javascript
将字符串中由空格隔开的每个单词首字母大写
2014/04/06 Javascript
jQuery遍历页面所有CheckBox查看是否被选中的方法
2015/04/14 Javascript
jQuery 1.9.1源码分析系列(十三)之位置大小操作
2015/12/02 Javascript
Javascript中级语法快速入手
2016/07/30 Javascript
JavaScript数组和对象的复制
2017/03/21 Javascript
xmlplus组件设计系列之网格(DataGrid)(10)
2017/05/05 Javascript
Vue.Draggable实现拖拽效果
2020/07/29 Javascript
浅析Angular19 自定义表单控件
2018/01/31 Javascript
webpack4.x打包过程详解
2018/07/18 Javascript
Vue 实现列表动态添加和删除的两种方法小结
2018/09/07 Javascript
微信小程序列表中item左滑删除功能
2018/11/07 Javascript
vue实现吸顶、锚点和滚动高亮按钮效果
2019/10/21 Javascript
Python fileinput模块使用实例
2015/05/28 Python
Python简单遍历字典及删除元素的方法
2016/09/18 Python
Python算法应用实战之栈详解
2017/02/04 Python
python常见排序算法基础教程
2017/04/13 Python
简单介绍python封装的基本知识
2019/08/10 Python
你可能不知道的Python 技巧小结
2020/01/29 Python
Python实现在Windows平台修改文件属性
2020/03/05 Python
美国婚礼和派对礼品网站:Kate Aspen(新娘送礼会、迎婴派对)
2018/03/28 全球购物
在线课程:Skillshare
2019/04/02 全球购物
Skyscanner香港:机票比价, 平机票和廉价航空机票预订
2020/02/07 全球购物
课程改革实施方案
2014/03/16 职场文书
师德师风承诺书
2014/05/23 职场文书
高中历史教学反思
2016/02/19 职场文书
解决Python字典查找报Keyerror的问题
2021/05/26 Python