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 相关文章推荐
js的alert弹出框出现乱码解决方案
Sep 02 Javascript
浅析js中的浮点型运算问题
Jan 06 Javascript
Linux下编译安装php libevent扩展实例
Feb 14 Javascript
基于jquery实现图片相关操作(重绘、获取尺寸、调整大小、缩放)
Dec 25 Javascript
关于javascript的一些知识以及循环详解
Sep 12 Javascript
js实现华丽的九九乘法表效果
Mar 29 Javascript
从零开始学习Node.js系列教程四:多页面实现的数学运算示例
Apr 13 Javascript
关于前后端json数据的发送与接收详解
Jul 30 Javascript
浅谈关于angularJs中使用$.ajax的注意点
Aug 12 Javascript
JavaScript选择排序算法原理与实现方法示例
Aug 06 Javascript
简单了解Javscript中兄弟ifream的方法调用
Jun 17 Javascript
详解Webpack抽离第三方类库以及common解决方案
Mar 30 Javascript
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 字符串 小常识
2009/06/05 PHP
php中让上传的文件大小在上传前就受限制的两种解决方法
2013/06/24 PHP
PHP错误Allowed memory size of 67108864 bytes exhausted的3种解决办法
2014/07/28 PHP
适合PHP初学者阅读的4本经典书籍
2016/09/23 PHP
javascript中的关于类型转换的性能优化
2010/12/14 Javascript
JavaScript中json对象和string对象之间相互转化
2012/12/26 Javascript
直接拿来用的页面跳转进度条JS实现
2016/01/06 Javascript
js基于cookie记录来宾姓名的方法
2016/07/19 Javascript
JavaScript实战之菜单特效
2016/08/16 Javascript
微信小程序 动画的简单实例
2017/10/12 Javascript
vue-router 组件复用问题详解
2018/01/22 Javascript
Vue.js 中的 v-cloak 指令及使用详解
2018/11/19 Javascript
js比较两个单独的数组或对象是否相等的实例代码
2019/04/28 Javascript
JS实现数组删除指定元素功能示例
2019/06/05 Javascript
vue使用高德地图根据坐标定位点的实现代码
2019/08/22 Javascript
JS Html转义和反转义(html编码和解码)的实现与使用方法总结
2020/03/10 Javascript
如何在Vue项目中添加接口监听遮罩
2021/01/25 Vue.js
[48:38]DOTA2亚洲邀请赛 3.31 小组赛 B组 Mineski vs Secret
2018/03/31 DOTA
对python中return和print的一些理解
2017/08/18 Python
浅谈机器学习需要的了解的十大算法
2017/12/15 Python
Python Flask基础教程示例代码
2018/02/07 Python
django框架自定义用户表操作示例
2018/08/07 Python
Python 给某个文件名添加时间戳的方法
2018/10/16 Python
python版飞机大战代码分享
2018/11/20 Python
python小程序之4名牌手洗牌发牌问题解析
2020/05/15 Python
在 Python 中使用 MQTT的方法
2020/08/18 Python
个人自我鉴定
2013/11/07 职场文书
幼儿园母亲节活动方案
2014/03/10 职场文书
委托书的格式
2014/08/01 职场文书
党的群众路线教育实践活动学习笔记范文
2014/11/06 职场文书
学生逃课万能检讨书2000字
2015/02/17 职场文书
整改通知书
2015/04/20 职场文书
亮剑观后感600字
2015/06/05 职场文书
2017新年晚会开幕词
2016/03/03 职场文书
浅谈怎么给Python添加类型标注
2021/06/08 Python
SpringBoot读取Resource下文件的4种方法
2021/07/02 Java/Android