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父窗口控制只弹出一个子窗口
Apr 10 Javascript
DWR Ext 加载数据
Mar 22 Javascript
js返回上一页并刷新代码整理
Dec 21 Javascript
jQuery获取对象简单实现方法小结
Oct 30 Javascript
纯js实现仿QQ邮箱弹出确认框
Apr 29 Javascript
Laydate时间组件在火狐浏览器下有多时间输入框时只能给第一个输入框赋值的解决方法
Aug 18 Javascript
JavaScript字符串_动力节点Java学院整理
Jun 27 Javascript
详解ES6之用let声明变量以及let loop机制
Jul 15 Javascript
js案例之鼠标跟随jquery版(实例讲解)
Jul 21 jQuery
原生JS实现列表子元素顺序反转的方法分析
Jul 02 Javascript
在vue中实现嵌套页面(iframe)
Jul 30 Javascript
JavaScript最完整的深浅拷贝实现方式详解
Feb 28 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 mysql_real_escape_string函数用法与实例教程
2013/09/30 PHP
php 防止表单重复提交两种实现方法
2016/11/03 PHP
php 截取GBK文档某个位置开始的n个字符方法
2017/03/08 PHP
PHP生成随机字符串实例代码(字母+数字)
2019/09/11 PHP
基于laravel where的高级使用方法
2019/10/10 PHP
来自国外的14个图片放大编辑的jQuery插件整理
2010/10/20 Javascript
IE中的File域无法清空使用jQuery重设File域
2014/04/24 Javascript
javascript的事件触发器介绍的实现
2014/06/05 Javascript
JS中三目运算符和if else的区别分析与示例
2014/11/21 Javascript
js实现图片上传并正常显示
2015/12/19 Javascript
Bootstrap.css与layDate日期选择样式起冲突的解决办法
2017/04/07 Javascript
node.js中debug模块的简单介绍与使用
2017/04/25 Javascript
Vue2.0实现购物车功能
2017/06/05 Javascript
详解微信UnionID作用
2019/05/15 Javascript
[40:19]完美世界DOTA2联赛PWL S3 Rebirth vs CPG 第二场 12.18
2020/12/19 DOTA
Python中操作mysql的pymysql模块详解
2016/09/13 Python
python实现excel读写数据
2021/03/02 Python
Python OpenCV中的resize()函数的使用
2019/06/20 Python
Python字符串处理的8招秘籍(小结)
2019/08/13 Python
Python 类,property属性(简化属性的操作),@property,property()用法示例
2019/10/12 Python
python 导入数据及作图的实现
2019/12/03 Python
python GUI编程(Tkinter) 创建子窗口及在窗口上用图片绘图实例
2020/03/04 Python
python使用信号量动态更新配置文件的操作
2020/04/01 Python
Python之多进程与多线程的使用
2021/02/23 Python
htnl5利用svg页面高斯模糊的方法
2018/07/20 HTML / CSS
澳大利亚制造的羊皮靴:Original UGG Boots
2017/11/13 全球购物
英国地毯卖家:The Rug Seller
2019/07/18 全球购物
WSDL的操作类型主要有几种
2013/07/19 面试题
复核员上岗演讲稿
2014/01/05 职场文书
自我鉴定三原则
2014/01/13 职场文书
工厂保安员岗位职责
2014/01/31 职场文书
体育教学随笔感言
2014/02/24 职场文书
《池塘边的叫声》教学反思
2014/04/12 职场文书
理财学专业自荐书
2014/06/28 职场文书
信访维稳承诺书
2015/05/04 职场文书
Python必备技巧之字符数据操作详解
2022/03/23 Python