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 有用的脚本函数
May 07 Javascript
10个基于浏览器的JavaScript调试工具分享
Feb 07 Javascript
Js保留小数点的4种效果实现代码分享
Apr 12 Javascript
javascript中parseInt()函数的定义和用法分析
Dec 20 Javascript
14个有用的Jquery技巧分享
Jan 08 Javascript
karma+webpack搭建vue单元测试环境的方法示例
May 24 Javascript
this.$toast() 了解一下?
Apr 18 Javascript
Node如何后台数据库使用增删改查功能
Nov 21 Javascript
Node中对非阻塞I/O、事件循环的知识点总结
Jan 05 Javascript
JS实现滑动拼图验证功能完整示例
Mar 29 Javascript
VUE页面中通过双击实现复制表格中内容的示例代码
Jun 11 Javascript
封装Vue Element的table表格组件的示例详解
Aug 19 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数组操作
2011/12/30 PHP
PHP实现无限级分类(不使用递归)
2015/10/22 PHP
在JavaScript中通过URL传递汉字的方法
2007/04/09 Javascript
Javascript模板技术
2007/04/27 Javascript
Knockoutjs的环境搭建教程
2012/11/26 Javascript
jquery插件冲突(jquery.noconflict)解决方法分享
2014/03/20 Javascript
浅谈jquery回调函数callback的使用
2015/01/30 Javascript
如何用js 实现依赖注入的思想,后端框架思想搬到前端来
2015/08/03 Javascript
JS基于clipBoard.js插件实现剪切、复制、粘贴
2016/05/03 Javascript
Bootstrap富文本组件wysiwyg数据保存到mysql的方法
2016/05/09 Javascript
网页瀑布流布局jQuery实现代码
2016/10/21 Javascript
JavaScript中的普通函数和箭头函数的区别和用法详解
2017/03/21 Javascript
JS时间控制实现动态效果的实例讲解
2017/07/31 Javascript
JavaScript数据结构与算法之队列原理与用法实例详解
2017/11/22 Javascript
通过JS运行机制的角度说说作用域
2019/03/12 Javascript
小程序表单认证布局及验证详解
2020/06/19 Javascript
JavaScript实现与web通信的方法详解
2020/08/07 Javascript
JavaScript实现通讯录功能
2020/12/27 Javascript
Python+树莓派+YOLO打造一款人工智能照相机
2018/01/02 Python
详解如何设置Python环境变量?
2019/05/13 Python
简单的Python调度器Schedule详解
2019/08/30 Python
检测tensorflow是否使用gpu进行计算的方式
2020/02/03 Python
python实现秒杀商品的微信自动提醒功能(代码详解)
2020/04/27 Python
python设置表格边框的具体方法
2020/07/17 Python
canvas小画板之平滑曲线的实现
2020/08/12 HTML / CSS
迪卡侬印度官网:购买所有体育用品
2017/06/24 全球购物
如何通过 CSS 写出火焰效果
2021/03/24 HTML / CSS
初中女生自我鉴定
2013/12/19 职场文书
成功的酒店创业计划书
2013/12/27 职场文书
文明和谐家庭事迹材料
2014/05/18 职场文书
个人授权委托书模板
2014/09/14 职场文书
财务出纳岗位职责
2015/03/31 职场文书
何玥事迹观后感
2015/06/16 职场文书
2016年艾滋病宣传活动总结
2016/04/01 职场文书
青年人初次创业的“五不要”
2019/08/23 职场文书
利用Python网络爬虫爬取各大音乐评论的代码
2021/04/13 Python