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常用经典算法实例详解
Nov 25 Javascript
JavaScript基础重点(必看)
Jul 09 Javascript
引用jquery框架后出错的解决方法
Aug 09 Javascript
angular 动态组件类型详解(四种组件类型)
Feb 22 Javascript
Vue.js在使用中的一些注意知识点
Apr 29 Javascript
详解vue-cli开发环境跨域问题解决方案
Jun 06 Javascript
解决Vue axios post请求,后台获取不到数据的问题方法
Aug 11 Javascript
微信小程序实现日期格式化和倒计时
Nov 01 Javascript
jquery+css3实现的经典弹出层效果示例
May 16 jQuery
Paypal支付不完全指北
Jun 04 Javascript
vue实现广告栏上下滚动效果
Nov 26 Vue.js
原生js实现弹幕效果
Nov 29 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如何解决网站大流量与高并发的问题
2011/06/25 PHP
curl不使用文件存取cookie php使用curl获取cookie示例
2014/01/26 PHP
PHP加Nginx实现动态裁剪图片方案
2014/03/10 PHP
PHP实现使用优酷土豆视频地址获取swf播放器分享地址
2014/06/05 PHP
php curl登陆qq后获取用户信息时证书错误
2015/02/03 PHP
php实现从上传文件创建缩略图的方法
2015/04/02 PHP
使用PHPCMS搭建wap手机网站
2015/09/20 PHP
PHP+MySQL统计该库中每个表的记录数并按递减顺序排列的方法
2016/02/15 PHP
Laravel框架Blade模板简介及模板继承用法分析
2019/12/03 PHP
基于jquery的给文章加入关键字链接
2010/10/26 Javascript
jquery仿QQ商城带左右按钮控制焦点图片切换滚动效果
2013/06/27 Javascript
jquery mobile changepage的三种传参方法介绍
2013/09/13 Javascript
JS实现图片放大镜效果的方法
2015/02/27 Javascript
javascript实现可键盘控制的抽奖系统
2016/03/10 Javascript
微信小程序 天气预报开发实例代码源码
2017/01/20 Javascript
js 实现复选框只能选择一项的示例代码
2018/01/23 Javascript
详解微信小程序开发之formId使用(模板消息)
2019/08/27 Javascript
vue路由拦截器和请求拦截器知识点总结
2019/11/08 Javascript
原生JS实现留言板功能
2020/02/08 Javascript
python图像处理之镜像实现方法
2015/05/30 Python
简单了解OpenCV是个什么东西
2017/11/10 Python
对Python中type打开文件的方式介绍
2018/04/28 Python
在双python下设置python3为默认的方法
2018/10/31 Python
详解numpy矩阵的创建与数据类型
2019/10/18 Python
Eclipse配置python默认头过程图解
2020/04/26 Python
蹦床仓库:Trampoline Warehouse
2018/12/06 全球购物
澳大利亚在线高跟鞋商店:Shoe Me
2019/11/19 全球购物
学习之星事迹材料
2014/05/17 职场文书
品牌转让协议书
2014/08/20 职场文书
股东大会通知
2015/04/24 职场文书
2016年寒假学习心得体会
2015/10/09 职场文书
html实现弹窗的实例
2021/06/09 HTML / CSS
Python基础之变量的相关知识总结
2021/06/23 Python
Vue Element-ui表单校验规则实现
2021/07/09 Vue.js
Shell脚本一键安装Nginx服务自定义Nginx版本
2022/03/20 Servers
vue css 相对路径导入问题级踩坑记录
2022/06/05 Vue.js