vue2中使用sass并配置全局的sass样式变量的方法


Posted in Javascript onSeptember 04, 2018

Sass语言

      Sass是一种强大的css扩展语言(css本身并不是一门语言),它允许你使用变量、嵌套规则、mixins、导入等css没有但开发语言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS语法。Sass有助于保持大型样式表结构良好。

      Sass有两种语法。

      一种称为SCSS,是一个CSS3语法的扩充版本,也就是说,所有符合CSS3语法的样式表也都是具有相同语法意义的SCSS文件,SCSS样式表文件要以.scss扩展名结尾。在vue中,我们可以使用<style lang="scss"></style>来标志里面的内容是以SCSS语法来书写的。

      一种称为SASS,是Sass以前的语法,它和python一样,没有{}大括号来标志程序块,而是以缩进来标志嵌套层级;而且也不使用分号,而是用换行符来分隔属性。SASS样式表文件要以.sass扩展名结尾。在vue中,我们可以使用<style lang="sass"></style>来标志里面的内容是以SASS语法来书写的。

在vue中使用样式文件sass,如果每个.vue文件都引入该样式,build出来文件后,势必会造成样式的重复,冗余,如果在main.js中全局引入一个scss文件,在其中定义变量在其他组件或者页面中引用报变量未定义错误,其他的样式可以正常显示,显然是编译的问题。那么,全局设置并加载样式就显得很有必要了!

首先,npm安装好

"sass-loader": "^6.0.7",
 "sass-resources-loader": "^1.3.3",

在build/webpack.base.conf.js中,在module的rules里添加

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

然后在build/utils.js文件中加入如下代码:

需要注意的是:我的全局样式是放在src/common/sass/index.scss中的

function resolveResouce(name) {
  return path.resolve(__dirname, '../src/common/sass/' + name);
 }
 function generateSassResourceLoader() {
  var loaders = [
   cssLoader,
   'postcss-loader',
   'sass-loader',
   {
    loader: 'sass-resources-loader',
    options: {
     //这是用到的sass文件,多个文件时用数组的形式传入,这是带有变量和mixin的scss文件
     resources: [resolveResouce('variable.scss'), resolveResouce('mixin.scss')] 注意这是我全局样式的位置,个人不同,需做调整
    }
   }
  ];
  if (options.extract) {
   return ExtractTextPlugin.extract({
    use: loaders,
    fallback: 'vue-style-loader'
   })
  } else {
   return ['vue-style-loader'].concat(loaders)
  }
 }

最后,将该页面下方的return部分,改成如下模样

return {
  css: generateLoaders(),
  postcss: generateLoaders(),
  less: generateLoaders('less'),
  //sass: generateLoaders('sass', { indentedSyntax: true }),
  //scss: generateLoaders('sass'),
  sass: generateSassResourceLoader(),
  scss: generateLoaders('sass')
   .concat(
    {
     loader: 'sass-resources-loader',
     options: {
      resources: path.resolve(__dirname, '../src/common/sass/index.scss') //注意这是我全局样式的位置,个人不同,需做调整
     }
    }
   ),
  stylus: generateLoaders('stylus'),
  styl: generateLoaders('stylus')
 }

总结

以上所述是小编给大家介绍的vue2中使用sass并配置全局的sass样式变量,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
基于jquery实现的定时显示与隐藏div广告的实现代码
Aug 22 Javascript
js分页代码分享
Apr 28 Javascript
JavaScript设置获取和设置属性的方法
Mar 04 Javascript
SWFObject基本用法实例分析
Jul 20 Javascript
基于JavaScript实现跳转提示页面
Sep 24 Javascript
基于vue-cli npm run build之后vendor.js文件过大的解决方法
Sep 27 Javascript
express框架下使用session的方法
Jul 31 Javascript
浅谈Vue项目骨架屏注入实践
Aug 05 Javascript
layer 关闭指定弹出层的例子
Sep 25 Javascript
关于JSON解析的实现过程解析
Oct 08 Javascript
javascript设计模式 ? 装饰模式原理与应用实例分析
Apr 14 Javascript
详解Vue router路由
Nov 20 Vue.js
Element UI 自定义正则表达式验证方法
Sep 04 #Javascript
在vue项目中引入高德地图及其UI组件的方法
Sep 04 #Javascript
使用validate.js实现表单数据提交前的验证方法
Sep 04 #Javascript
快速解决vue-cli在ie9+中无效的问题
Sep 04 #Javascript
快速解决Vue项目在IE浏览器中显示空白的问题
Sep 04 #Javascript
create-react-app安装出错问题解决方法
Sep 04 #Javascript
解决vue-cli项目打包出现空白页和路径错误的问题
Sep 04 #Javascript
You might like
PHP 异步执行方法,模拟多线程的应用分析
2013/06/03 PHP
PHP合并数组+号和array_merge的区别
2015/06/25 PHP
以文件形式缓存php变量的方法
2015/06/26 PHP
js 日期比较相关天数代码
2014/04/02 Javascript
jQuery中innerHeight()方法用法实例
2015/01/19 Javascript
javascript实现复选框选中属性
2015/03/25 Javascript
Javascript实现的Map集合工具类完整实例
2015/07/31 Javascript
全面解析Bootstrap布局组件应用
2016/02/22 Javascript
Jquery实现的简单轮播效果【附实例】
2016/04/19 Javascript
Node.js 中exports 和 module.exports 的区别
2017/03/14 Javascript
JS中的数组转变成JSON格式字符串的方法
2017/05/09 Javascript
基于Proxy的小程序状态管理实现
2019/06/14 Javascript
详解简单易懂的 ES6 Iterators 指南和示例
2019/09/24 Javascript
JS图片懒加载的优点及实现原理
2020/01/10 Javascript
[54:08]LGD女子刀塔学院 DOTA2炼金术士教学
2014/01/09 DOTA
Python操作SQLite简明教程
2014/07/10 Python
Python文档生成工具pydoc使用介绍
2015/06/02 Python
python字典的常用操作方法小结
2016/05/16 Python
matplotlib在python上绘制3D散点图实例详解
2017/12/09 Python
一道python走迷宫算法题
2018/01/22 Python
Python实现统计给定字符串中重复模式最高子串功能示例
2018/05/16 Python
python保存数据到本地文件的方法
2018/06/23 Python
树莓派实现移动拍照
2019/06/22 Python
Flask框架请求钩子与request请求对象用法实例分析
2019/11/07 Python
Python二元算术运算常用方法解析
2020/09/15 Python
MyHeritage美国:家族史研究和DNA测试的领先服务
2019/05/27 全球购物
大学生职业规划范文:象牙塔生活的四年计划
2014/01/14 职场文书
巡警年度自我鉴定
2014/02/21 职场文书
单位委托书范本
2014/04/04 职场文书
调研座谈会发言材料
2014/08/23 职场文书
2014年国庆晚会主持词
2014/09/19 职场文书
群众路线教育实践活动对照检查材料思想汇报(副处级领导)
2014/10/04 职场文书
安全教育片观后感
2015/06/17 职场文书
格列佛游记读书笔记
2015/06/30 职场文书
2015迎新晚会活动总结
2015/07/16 职场文书
解析MySQL binlog
2021/06/11 MySQL