在写项目的过程中,如果用的是scss来编写样式代码,常常需要定义各种变量,例如主题色、主字号之类的,因此我们会把这些变量写到一个单独的_variable.scss文件内,但是每次都要在vue单文件内引入这些变量未免太繁琐了,所以有没有办法可以默认把变量文件作为全局文件进行引入呢?答案是肯定的,可以用下面的方法进行配置,可以根据当前使用的框架和环境来进行方法的选择。
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. 重启项目,即可在其他文件内使用这些变量文件了
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官网中看到此说明。【传送门】
因此,我们需要将配置代码修改成如下样式:
css: { loaderOptions: { sass: { prependData: `@import "~@/styles/_variable.scss";` } } }
好了,重启一下项目,大功告成。
以上就是vue中配置scss全局变量的步骤的详细内容,更多关于vue配置scss全局变量的资料请关注站长技术其它相关文章!
数据展示,一直是各行各业乐此不疲的需求,具体到前端开发行业,则是各种各种图...
本文实例讲述了PHP 扩展Memcached命令用法。分享给大家供大家参考,具体如下: ...
1月18日消息 外媒 Windows Latest 报道,当 Windows 10X 在 2019 年首次公布时,...
Session Initiation Protocol 介绍 SIP是VoIP技术最常使用的协议,它是一种应用...
本文实例讲述了Thinkphp 框架扩展之驱动扩展。分享给大家供大家参考,具体如下:...
php实现微信支付 微信支付文档地址: https://pay.weixin.qq.com/wiki/doc/api/i...
3月13日消息Mozilla 已经 发布了 Firefox 火狐浏览器的 86.0.1 更新 ,此次更新...
每周学习4.1-4.7 阅读backbone相关网络模型(轻量级网络MobileNetv1,v2,v3和Shuff...
MySQL 整理 数据库概念 ACID ACID是事物的四个特性。分别是 原?性 (Atomicity)、...
前言 一步一步地实践已成熟的flink1.12以parcel方式部署cdh6.x。 编译 下载 kafk...