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 相关文章推荐
另类调用flash无须激活的方法
Dec 27 Javascript
JavaScript 处理Iframe自适应高度(同或不同域名下)
Mar 29 Javascript
HTML页面滚动时获取离页面顶部的距离2种实现方法
Sep 05 Javascript
JS操作数据库的实例代码
Oct 17 Javascript
node.js Web应用框架Express入门指南
May 28 Javascript
js+html5获取用户地理位置信息并在Google地图上显示的方法
Jun 05 Javascript
JavaScript中利用各种循环进行遍历的方式总结
Nov 10 Javascript
基于jquery实现省市区三级联动效果
Dec 25 Javascript
解决webpack无法通过IP地址访问localhost的问题
Feb 22 Javascript
vue中keep-alive内置组件缓存的实例代码
Apr 16 Javascript
nuxt 自定义 auth 中间件实现令牌的持久化操作
Nov 05 Javascript
JS实现简单九宫格抽奖
Jun 28 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开发中的页面跳转方法总结
2015/04/26 PHP
Yii编程开发常见调用技巧集锦
2016/07/15 PHP
使用新的消息弹出框blackbirdjs
2008/10/16 Javascript
jQuery检查事件是否触发的方法
2015/06/26 Javascript
Javascript验证Visa和MasterCard信用卡号的方法
2015/07/27 Javascript
jquery实现手机号码选号的方法
2015/07/31 Javascript
html+js+highcharts绘制圆饼图表的简单实例
2016/08/04 Javascript
jQuery dataTables与jQuery UI 对话框dialog的使用教程
2016/09/02 Javascript
jQuery获取复选框选中的当前行的某个字段的值
2017/09/15 jQuery
JS字典Dictionary类定义与用法示例
2019/02/01 Javascript
Vue自定义指令写法与个人理解
2019/02/09 Javascript
js设置鼠标悬停改变背景色实现详解
2019/06/26 Javascript
vue项目在线上服务器访问失败原因分析
2020/08/14 Javascript
带你使用webpack快速构建web项目的方法
2020/11/12 Javascript
python抓取网页内容示例分享
2014/02/24 Python
python生成指定尺寸缩略图的示例
2014/05/07 Python
Python正则抓取网易新闻的方法示例
2017/04/21 Python
Python 操作MySQL详解及实例
2017/04/30 Python
python3+PyQt5实现柱状图
2018/04/24 Python
Python函数装饰器实现方法详解
2018/12/22 Python
浅谈tensorflow之内存暴涨问题
2020/02/05 Python
Python 序列化和反序列化库 MarshMallow 的用法实例代码
2020/02/25 Python
Python如何发送与接收大型数组
2020/08/07 Python
Perfume’s Club意大利官网:欧洲美妆电商
2019/05/03 全球购物
热门专业求职信
2014/05/24 职场文书
汽车广告策划方案
2014/05/31 职场文书
我的中国梦演讲稿600字
2014/08/19 职场文书
解除劳动合同协议书(样本)
2014/10/02 职场文书
2015年发展党员工作总结报告
2015/03/31 职场文书
物业工程部经理岗位职责
2015/04/09 职场文书
小学生勤俭节约倡议书
2015/04/29 职场文书
2015年中学总务处工作总结
2015/07/22 职场文书
新店开业策划方案怎么书写?
2019/07/05 职场文书
导游词之山海关
2019/12/10 职场文书
PostgreSQL基于pgrouting的路径规划处理方法
2022/04/18 PostgreSQL
人工智能深度学习OpenAI baselines的使用方法
2022/05/20 Python