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 字符 Escape,encodeURI,encodeURIComponent
Jul 09 Javascript
javascript 设为首页与加入收藏兼容多浏览器代码
Jan 11 Javascript
js播放wav文件(源码)
Apr 22 Javascript
jquery 获取标签名(tagName)示例代码
Jul 11 Javascript
javascript同页面多次调用弹出层具体实例代码
Aug 16 Javascript
JavaScript中“过于”犀利地for/in循环使用示例
Oct 22 Javascript
BOM系列第三篇之定时器应用(时钟、倒计时、秒表和闹钟)
Aug 17 Javascript
原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果
May 03 Javascript
bootstrap treeview 树形菜单带复选框及级联选择功能
Jun 08 Javascript
微信小程序官方动态自定义底部tabBar的例子
Sep 04 Javascript
JS实现碰撞检测效果
Mar 12 Javascript
vue 虚拟DOM的原理
Oct 03 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造成压力的解决方法
2013/02/21 PHP
PHP资源管理框架Assetic简介
2014/06/12 PHP
PHP+swoole+linux实现系统监控和性能优化操作示例
2019/04/15 PHP
PHP call_user_func和call_user_func_array函数的简单理解与应用分析
2019/11/25 PHP
Javascript 刷新全集常用代码
2009/11/22 Javascript
js禁止页面使用右键(简单示例代码)
2013/11/13 Javascript
jQuery中验证表单提交方式及序列化表单内容的实现
2014/01/06 Javascript
jquery实现预览提交的表单代码分享
2014/05/21 Javascript
借助JavaScript脚本判断浏览器Flash Player信息的方法
2014/07/09 Javascript
详解AngularJS 模态对话框
2016/04/07 Javascript
Adapter适配器模式在JavaScript设计模式编程中的运用分析
2016/05/18 Javascript
js获取所有checkbox的值的简单实例
2016/05/30 Javascript
AngularJs基于角色的前端访问控制的实现
2016/11/07 Javascript
bootstrap——bootstrapTable实现隐藏列的示例
2017/01/14 Javascript
微信小程序中子页面向父页面传值实例详解
2017/03/20 Javascript
如何对react hooks进行单元测试的方法
2019/08/14 Javascript
vue实现输入框的模糊查询的示例代码(节流函数的应用场景)
2019/09/01 Javascript
Vant Weapp组件踩坑:picker的初始赋值解决
2020/11/12 Javascript
浅谈python中截取字符函数strip,lstrip,rstrip
2015/07/17 Python
python中列表和元组的区别
2017/12/18 Python
python无限生成不重复(字母,数字,字符)组合的方法
2018/12/04 Python
Python django框架应用中实现获取访问者ip地址示例
2019/05/17 Python
Matplotlib使用字符串代替变量绘制散点图的方法
2020/02/17 Python
keras.utils.to_categorical和one hot格式解析
2020/07/02 Python
用Python制作mini翻译器的实现示例
2020/08/17 Python
财务与信息服务专业推荐信
2013/11/28 职场文书
《燕子》教学反思
2014/02/18 职场文书
《生命 生命》教学反思
2014/04/19 职场文书
烹饪大赛策划方案
2014/05/26 职场文书
保卫钓鱼岛口号
2014/06/20 职场文书
2014党支部对照检查材料思想汇报
2014/10/05 职场文书
介绍信范文
2015/01/31 职场文书
公司环境卫生管理制度
2015/08/05 职场文书
mysql对于模糊查询like的一些汇总
2021/05/09 MySQL
MySQL中utf8mb4排序规则示例
2021/08/02 MySQL
idea 在springboot中使用lombok插件的方法
2021/08/02 Java/Android