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 25 Vue.js
Vue用mixin合并重复代码的实现
Nov 27 Vue.js
vue使用exif获取图片旋转,压缩的示例代码
Dec 11 Vue.js
Vue 组件注册全解析
Dec 17 Vue.js
Vue实现简易购物车页面
Dec 30 Vue.js
Vue项目中使用mock.js的完整步骤
Jan 12 Vue.js
如何在vue中使用HTML 5 拖放API
Jan 14 Vue.js
Vue ​v-model相关知识总结
Jan 28 Vue.js
vue脚手架项目创建步骤详解
Mar 02 Vue.js
vue3.0 项目搭建和使用流程
Mar 04 Vue.js
vue组件的路由高亮问题解决方法
May 11 Vue.js
vue.js Router中嵌套路由的实用示例
Jun 27 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程序
2012/02/04 PHP
PHP静态文件生成类实例
2014/11/29 PHP
使用PHP+MySql实现微信投票功能实例代码
2017/09/29 PHP
PHP Swoole异步读取、写入文件操作示例
2019/10/24 PHP
离开页面时检测表单元素是否被修改,提示保存的js代码
2010/08/25 Javascript
深入理解javascript作用域和闭包
2014/09/23 Javascript
JavaScript中用字面量创建对象介绍
2014/12/31 Javascript
Angularjs中如何使用filterFilter函数过滤
2016/02/06 Javascript
vue params、query传参使用详解
2017/09/12 Javascript
vue 权限认证token的实现方法
2018/07/17 Javascript
JS实现的新闻列表自动滚动效果示例
2019/01/30 Javascript
实现elementUI表单的全局验证的方法步骤
2019/04/29 Javascript
Layui多选只有最后一个值的解决方法
2019/09/02 Javascript
js实现小星星游戏
2020/03/23 Javascript
Javascript实现简易天数计算器
2020/05/18 Javascript
python中遍历文件的3个方法
2014/09/02 Python
python机器学习之神经网络(二)
2017/12/20 Python
Python 爬虫之Beautiful Soup模块使用指南
2018/07/05 Python
python实现飞机大战
2018/09/11 Python
python学习之hook钩子的原理和使用
2018/10/25 Python
Win10环境python3.7安装dlib模块趟过的坑
2019/08/01 Python
python实现超级玛丽游戏
2020/03/18 Python
python操作redis数据库的三种方法
2020/09/10 Python
Python创建自己的加密货币的示例
2021/03/01 Python
时尚圣经:The Fashion Bible
2019/03/03 全球购物
官方授权图形T恤和服装:Fifth Sun
2019/06/12 全球购物
Dyson戴森波兰官网:Dyson.pl
2019/08/05 全球购物
介绍一些UNIX常用简单命令
2014/11/11 面试题
餐饮服务食品安全责任书
2014/07/25 职场文书
教育实践活动对照检查材料
2014/09/23 职场文书
2014年宣传部个人工作总结
2014/12/06 职场文书
2015年女职工工作总结
2015/05/15 职场文书
离职证明范本
2015/06/12 职场文书
小学四年级班主任工作经验交流材料
2015/11/02 职场文书
聊聊redis-dump工具安装问题
2022/01/18 Redis
Java实现字符串转为驼峰格式的方法详解
2022/07/07 Java/Android