Vue引入sass并配置全局变量的方法


Posted in Javascript onJune 27, 2018

引入sass

首先使用官方提供的脚手架vue-cli进行搭建框架,这里就不做说明了,查阅官网即可。

等安装完所有依赖后,安装sass的依赖包:

npm install --save-dev sass-loader
//sass-loader依赖于node-sass
npm install --save-dev node-sass

然后在build文件夹下的webpack.base.conf.js的rules里面添加配置:

{
 test: /\.sass$/,
 loaders: ['style', 'css', 'sass']
}

然后添加csslang属性。注意,这里是scss,而且css文件的后缀也是scss:

<style lang="scss"></style>

最后需要重新编译一下项目,否则没有效果。

$ npm run dev

现在就可以随意的使用sass了,这时候会发现如果我想定义几个变量进行全局使用,好像只能在页面中通过@import来引入,这显然不够优雅,可以这样解决。

配置sass全局变量

有一个babel插件可以完美的解决这个问题:sass-resources-loader可以访问sass资源任何一个需要访问的sass模块。所以,可以使用共享变量和混合所有SASS样式,而不去每个文件都引用。

首先进行插件安装:

npm install --save-dev sass-resources-loader

然后在 build 文件夹下找到 util.js 修改sass编译器loader的配置,直接把下面的代码复制进去即可:

// 全局文件引入 当然只想编译一个文件的话可以省去这个函数
function resolveResource(name) {
 return path.resolve(__dirname, '../src/style/' + name);
}
function generateSassResourceLoader() {
 var loaders = [
  cssLoader,
  'sass-loader',
  {
   loader: 'sass-resources-loader',
   options: {
    // 多个文件时用数组的形式传入,单个文件时可以直接使用 path.resolve(__dirname, '../static/style/common.scss'
    resources: [resolveResource('theme.scss')] 
   }
  }
  ];
  if (options.extract) {
   return ExtractTextPlugin.extract({
    use: loaders,
    fallback: 'vue-style-loader'
   })
  } else {
   return ['vue-style-loader'].concat(loaders)
  }
 }

将默认的sass配置改为 generateSassResourceLoader()。

return {
  css: generateLoaders(),
  postcss: generateLoaders(),
  less: generateLoaders('less'),
  // vue-cli默认sass配置
  // sass: generateLoaders('sass', { indentedSyntax: true }), 
  // scss: generateLoaders('sass'),
  // 新引入的sass-resources-loader
  sass: generateSassResourceLoader(),
  scss: generateSassResourceLoader(),
  stylus: generateLoaders('stylus'),
  styl: generateLoaders('stylus')
 }

改完配置后重启服务就可以在theme.scss里定义全局变量并在页面中引用了。

需要注意的是,scss里的变量是$开头,而less里的变量是@开头。比如我想定义一个项目的主色调变量,我可以在theme.scss里这样定义:

$c-primary: #fd7a00;
$theme-blue: #3296fa;
$theme-red: #da3838;

引用变量的时候直接引用变量名即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
仿服务器端脚本方式的JS模板实现方法
Apr 27 Javascript
javascript 弹出窗口中是否显示地址栏的实现代码
Apr 14 Javascript
$.extend 的一个小问题
Jun 18 Javascript
jquery左右全屏大尺寸多图滑动效果代码分享
Aug 28 Javascript
js实现的二分查找算法实例
Jan 21 Javascript
基于canvas实现的绚丽圆圈效果完整实例
Jan 26 Javascript
jQuery事件的绑定、触发、及监听方法简单说明
May 10 Javascript
jQuery中slidedown与slideup方法用法示例
Sep 16 Javascript
对javascript继承的理解
Oct 11 Javascript
vue配置font-awesome5的方法步骤
Jan 27 Javascript
layui 数据表格复选框实现单选功能的例子
Sep 19 Javascript
使用eslint和githooks统一前端风格的技巧
Jul 29 Javascript
详解解决使用axios发送json后台接收不到的问题
Jun 27 #Javascript
vue中v-model的应用及使用详解
Jun 27 #Javascript
JS基于封装函数实现的表格分页完整示例
Jun 26 #Javascript
Vue实现todolist删除功能
Jun 26 #Javascript
AngularJS实现动态切换样式的方法分析
Jun 26 #Javascript
详解VUE自定义组件中用.sync修饰符与v-model的区别
Jun 26 #Javascript
jQuery实现ajax回调函数带入参数的方法示例
Jun 26 #jQuery
You might like
php数据入库前清理 注意php intval与mysql的int取值范围不同
2010/12/12 PHP
如何使用Linux的Crontab定时执行PHP脚本的方法
2011/12/19 PHP
php用header函数实现301跳转代码实例
2013/11/25 PHP
jQuery 获取URL参数的插件
2010/03/04 Javascript
让JavaScript拥有类似Lambda表达式编程能力的方法
2010/09/12 Javascript
js数组方法扩展实现数组统计函数
2014/04/09 Javascript
javascript ajax的5种状态介绍
2014/08/18 Javascript
jQuery使用height()获取高度需要注意的地方
2014/12/13 Javascript
js中的内部属性与delete操作符介绍
2015/08/10 Javascript
纯js代码实现简单计算器
2015/12/02 Javascript
javascript数组去重小结
2016/03/07 Javascript
喜大普奔!jQuery发布 3.0 最终版
2016/06/12 Javascript
简单封装js的dom查询实例代码
2016/07/08 Javascript
JavaScript获取URL中参数querystring的方法详解
2016/10/11 Javascript
详解JavaScript中this的指向问题
2017/01/20 Javascript
jQuery代码实现实时获取时间
2017/01/29 Javascript
js图片延迟加载(Lazyload)三种实现方式
2017/03/01 Javascript
Vue制作Todo List网页
2017/04/26 Javascript
日期时间范围选择插件:daterangepicker使用总结(必看篇)
2017/09/14 Javascript
vue-cli3.0+element-ui上传组件el-upload的使用
2018/12/03 Javascript
vue实现todolist功能、todolist组件拆分及todolist的删除功能
2019/04/11 Javascript
茶余饭后聊聊Vue3.0响应式数据那些事儿
2019/10/30 Javascript
JS面向对象编程实现的拖拽功能案例详解
2020/03/03 Javascript
js 解析 JSON 数据简单示例
2020/04/21 Javascript
Python 通过pip安装Django详细介绍
2017/04/28 Python
Python计算两个日期相差天数的方法示例
2017/05/23 Python
Python检查和同步本地时间(北京时间)的实现方法
2018/12/03 Python
Python对象与引用的介绍
2019/01/24 Python
Pycharm 文件更改目录后,执行路径未更新的解决方法
2019/07/19 Python
python 微信好友特征数据分析及可视化
2020/01/07 Python
Python使用pycharm导入pymysql教程
2020/09/16 Python
企划专员岗位职责
2013/12/09 职场文书
餐厅销售主管职责范本
2014/02/19 职场文书
房屋登记授权委托书范本
2014/10/09 职场文书
有关花店创业的计划书模板
2019/08/27 职场文书
React forwardRef的使用方法及注意点
2021/06/13 Javascript