vue项目中使用scss的方法步骤


Posted in Javascript onMay 16, 2019

一 概述

随着sass/less等css预处理器的出现,编写css变的越来越有乐趣。所以现在越来越多的人在项目中喜欢使用scss或者less。(我自己就是一个)。由于最近在写一个vue项目。所以就把写项目期间每天的一些知识点写在博客里。所以最近的博客应该都会和vue有关。今天要和大家分享的就是如何在vue项目中引入scss(引入less也类似)

二 vue中引入scss

2.1 vue-loader

在讲如何在vue项目中使用scss之前,我们先来简单了解一个概念,那就是vue-loader。vue-loader是什么东西呢?vue-loader其实就是一个webpack的loader。用来把vue组件转换成可部署的js,html,css模块。所以我们如果要想再vue项目中使用scss,肯定要告诉vue-loader怎么样解析我的scss文件。

不了解webpack的同学可以先去自行百度。我这里就放一张图,看完大家可以也就能知道webpack能做些什么事情了。

vue项目中使用scss的方法步骤

2.2 loader配置

在webpack中,所有预处理器都要匹配相应的loader,vue-loader允许其他的webpack-loader处理组件中的一部分吗,然后它根据lang属性自动判断出要使用的loaders。所以,其实只要安装处理sass/scss的loader。就能在vue中使用scss了。

现在我们来安装sass/scss loader

npm install sass-loader node-sass --save-dev

2.3 为什么无需配置

我们前面说到,vue-loader允许能根据lang属性自动判断出要使用的loaders。它是怎么样做到的?有这么神奇嘛?我们下面来看一看最核心部分的源代码

exports.cssLoaders = function (options) {
 options = options || {}

 var cssLoader = {
  loader: 'css-loader',
  options: {
   minimize: process.env.NODE_ENV === 'production',
   sourceMap: options.sourceMap
  }
 }

 // generate loader string to be used with extract text plugin
 function generateLoaders (loader, loaderOptions) {
  var loaders = [cssLoader]
  if (loader) {
   loaders.push({
    loader: loader + '-loader',
    options: Object.assign({}, loaderOptions, {
     sourceMap: options.sourceMap
    })
   })
  }

  // Extract CSS when that option is specified
  // (which is the case during production build)
  if (options.extract) {
   return ExtractTextPlugin.extract({
    use: loaders,
    fallback: 'vue-style-loader'
   })
  } else {
   return ['vue-style-loader'].concat(loaders)
  }
 }

 // https://vue-loader.vuejs.org/en/configurations/extract-css.html
 return {
  css: generateLoaders(),
  postcss: generateLoaders(),
  less: generateLoaders('less'),
  sass: generateLoaders('sass', { indentedSyntax: true }),
  scss: generateLoaders('sass'),
  stylus: generateLoaders('stylus'),
  styl: generateLoaders('stylus')
 }
}

就是上述这段代码让vue-loader有了这种能力,它会根据不同的文件去使用不同的loader

2.4 使用scss

这样你就可以愉快的使用scss了。

<style scoped lang="sass">
   xxxx
   xxxx
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript使用prototype定义对象类型(转)[
Dec 22 Javascript
奇妙的js
Sep 24 Javascript
根据对象的某一属性进行排序的js代码(如:name,age)
Aug 10 Javascript
Javascript和HTML5利用canvas构建Web五子棋游戏实现算法
Jul 17 Javascript
js鼠标滑过图片震动特效的方法
Feb 17 Javascript
深入理解JavaScript系列(46):代码复用模式(推荐篇)详解
Mar 04 Javascript
javascript操作表格排序实例分析
May 06 Javascript
js HTML5多媒体影音播放
Oct 17 Javascript
使用Vue写一个datepicker的示例
Jan 27 Javascript
layui添加动态菜单与选项卡 AJAX请求的例子
Sep 25 Javascript
解决vue自定义全局消息框组件问题
Nov 22 Javascript
vue+elementui实现点击table中的单元格触发事件--弹框
Jul 18 Javascript
微信小程序云开发使用方法新手初体验
May 16 #Javascript
angular多语言配置详解
May 16 #Javascript
详解基于mpvue微信小程序下载远程图片到本地解决思路
May 16 #Javascript
Django模板继承 extend标签实例代码详解
May 16 #Javascript
vue视图不更新情况详解
May 16 #Javascript
详解如何写出一个利于扩展的vue路由配置
May 16 #Javascript
Vue中props的详解
May 16 #Javascript
You might like
超小PHP小马小结(方便查找后门的朋友)
2012/05/05 PHP
PHP+FastCGI+Nginx配置PHP运行环境
2014/08/07 PHP
php合并数组中相同元素的方法
2014/11/13 PHP
Yii使用migrate命令执行sql语句的方法
2016/03/15 PHP
Smarty高级应用之缓存操作技巧分析
2016/05/14 PHP
Docker 如何布置PHP开发环境
2016/06/21 PHP
js 优化次数过多的循环 考虑到性能问题
2011/03/05 Javascript
jquery中通过过滤器获取表单元素的实现代码
2011/07/05 Javascript
javascript中clone对象详解
2014/12/03 Javascript
angularJS中router的使用指南
2015/02/09 Javascript
JS中使用apply、bind实现为函数或者类传入动态个数的参数
2016/04/26 Javascript
再次谈论Javascript中的this
2016/06/23 Javascript
JS实现的表格行上下移动操作示例
2016/08/03 Javascript
Angular2数据绑定详解
2017/04/18 Javascript
vue音乐播放器插件vue-aplayer的配置及其使用实例详解
2017/07/10 Javascript
js中this的指向问题归纳总结
2018/11/28 Javascript
JS学习笔记之原型链和利用原型实现继承详解
2019/05/29 Javascript
解决VUE 在IE下出现ReferenceError: Promise未定义的问题
2020/11/07 Javascript
[01:15]《辉夜杯》北京网鱼队巡礼
2015/10/26 DOTA
[54:56]DOTA2上海特级锦标赛主赛事日 - 5 总决赛Liquid VS Secret第三局
2016/03/06 DOTA
python修改操作系统时间的方法
2015/05/18 Python
使用python编写简单的小程序编译成exe跑在win10上
2018/01/15 Python
简单了解django缓存方式及配置
2019/07/19 Python
Django实现CAS+OAuth2的方法示例
2019/10/30 Python
python如何编写win程序
2020/06/08 Python
Django搭建项目实战与避坑细节详解
2020/12/06 Python
美国时尚孕妇装品牌:A Pea in the Pod
2017/07/16 全球购物
英国No.1体育用品零售商:SportsDirect.com
2019/10/16 全球购物
教师队伍管理制度
2014/01/14 职场文书
人事代理委托书
2014/09/27 职场文书
乡镇党建工作汇报材料
2014/10/27 职场文书
送达通知书
2015/04/25 职场文书
2016年春节慰问信息大全
2015/11/30 职场文书
2016年党员干部廉政承诺书
2016/03/24 职场文书
赞美教师的句子
2019/09/02 职场文书
ubuntu端向日葵键盘输入卡顿问题及解决
2022/12/24 Servers