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 相关文章推荐
小议javascript 设计模式 推荐
Oct 28 Javascript
C#中TrimStart,TrimEnd,Trim在javascript上的实现
Jan 17 Javascript
javascript对中文按照拼音排序代码
Aug 20 Javascript
JQuery分屏指示器图片轮换效果实例
May 21 Javascript
jQuery实现的指纹扫描效果实例(附演示与demo源码下载)
Jan 26 Javascript
基于d3.js实现实时刷新的折线图
Aug 03 Javascript
微信小程序页面生命周期详解
Jan 31 Javascript
js中DOM事件绑定分析
Mar 18 Javascript
jQuery+datatables插件实现ajax加载数据与增删改查功能示例
Apr 17 jQuery
浅谈如何使用webpack构建多页面应用
May 30 Javascript
详解html-webpack-plugin插件(用法总结)
Sep 12 Javascript
jQuery 添加元素和删除元素的方法
Jul 15 jQuery
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
法兰绒滤网冲泡
2021/03/03 冲泡冲煮
php站内搜索并高亮显示关键字的实现代码
2011/12/29 PHP
解析dedecms空间迁移步骤详解
2013/05/15 PHP
Laravel框架学习笔记(一)环境搭建
2014/10/15 PHP
Laravel 5.4向IoC容器中添加自定义类的方法示例
2017/08/15 PHP
PHP7 mongoDB扩展使用的方法分享
2019/05/02 PHP
javascript之水平横向滚动歌词同步的应用
2007/05/07 Javascript
jquery 常用操作整理 基础入门篇
2009/10/14 Javascript
js 巧妙去除数组中的重复项
2010/01/25 Javascript
JS获得QQ号码的昵称,头像,生日的简单实例
2013/12/04 Javascript
JS实现的数组全排列输出算法
2015/03/19 Javascript
js中删除数组中的某一元素实例(无下标时)
2017/02/28 Javascript
vue.js实现刷新当前页面的方法教程
2017/07/05 Javascript
Vue组件和Route的生命周期实例详解
2018/02/10 Javascript
ES6 Set结构的应用实例分析
2019/06/26 Javascript
[01:08]DOTA2次级职业联赛 - Shield战队宣传片
2014/12/01 DOTA
[05:15]2018年度CS GO社区贡献奖-完美盛典
2018/12/16 DOTA
python实现的一个p2p文件传输实例
2014/06/04 Python
python生成二维码的实例详解
2017/10/29 Python
python 根据时间来生成唯一的字符串方法
2019/01/14 Python
python面试题小结附答案实例代码
2019/04/11 Python
OpenCV 边缘检测
2019/07/10 Python
python的几种矩阵相乘的公式详解
2019/07/10 Python
Django多数据库的实现过程详解
2019/08/01 Python
python操作openpyxl导出Excel 设置单元格格式及合并处理代码实例
2019/08/27 Python
Django使用list对单个或者多个字段求values值实例
2020/03/31 Python
scrapy在python爬虫中搭建出错的解决方法
2020/11/22 Python
Watchshop德国:欧洲在线手表No.1
2019/06/20 全球购物
New Balance德国官方网站:购买鞋子和服装
2019/08/31 全球购物
《雪地里的小画家》教学反思
2014/02/22 职场文书
水利水电建筑施工应届生求职信
2014/07/04 职场文书
2014年材料员工作总结
2014/11/19 职场文书
2014年体育工作总结
2014/11/24 职场文书
家长意见书
2015/06/04 职场文书
大学军训口号大全
2015/12/24 职场文书
幼儿园2016年圣诞活动总结
2016/03/31 职场文书