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 相关文章推荐
img的onload的另类用法
Jan 10 Javascript
JavaScript动态创建div属性和样式示例代码
Oct 09 Javascript
javascript实现五星评分功能
Nov 10 Javascript
jQuery图片轮播实现并封装(一)
Dec 03 Javascript
懒加载实现的分页&amp;&amp;网站footer自适应
Dec 21 Javascript
基于EasyUI的基础之上实现树形功能菜单
Jun 28 Javascript
微信小程序 页面跳转事件绑定的实例详解
Sep 20 Javascript
axios进阶实践之利用最优雅的方式写ajax请求
Dec 20 Javascript
js中int和string数据类型互相转化实例
Jan 16 Javascript
Vue在chrome44偶现点击子元素事件无法冒泡的解决方法
Dec 15 Javascript
vue的$http的get请求要加上params操作
Nov 12 Javascript
Vue中computed和watch有哪些区别
Dec 19 Vue.js
微信小程序云开发使用方法新手初体验
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/09/13 PHP
PHP检测移动设备类mobile detection使用实例
2014/04/14 PHP
TP5框架实现自定义分页样式的方法示例
2020/04/05 PHP
静态页面的值传递(三部曲)
2006/09/25 Javascript
JS实现侧悬浮浮动实例代码
2013/11/29 Javascript
使用jquery解析XML示例代码
2014/09/05 Javascript
JavaScript中遍历对象的property的3种方法介绍
2014/12/30 Javascript
在Mac OS下使用Node.js的简单教程
2015/06/24 Javascript
基于jquery实现放大镜效果
2015/08/17 Javascript
详解设置Webstorm 利用babel将ES6自动转码成ES5
2017/12/20 Javascript
微信小程序wx.uploadfile 本地文件转base64的实现代码
2018/06/28 Javascript
vue-cli3环境变量与分环境打包的方法示例
2019/02/18 Javascript
jquery 回调操作实例分析【回调成功与回调失败的情况】
2019/09/27 jQuery
小程序Scroll-view上拉滚动刷新数据
2020/06/21 Javascript
[02:48]DOTA2英雄基础教程 拉席克
2013/12/12 DOTA
python备份文件以及mysql数据库的脚本代码
2013/06/10 Python
python中的__init__ 、__new__、__call__小结
2014/04/25 Python
Python判断操作系统类型代码分享
2014/11/22 Python
Python单链表简单实现代码
2016/04/27 Python
Python 实现文件的全备份和差异备份详解
2016/12/27 Python
python消费kafka数据批量插入到es的方法
2018/12/27 Python
python将邻接矩阵输出成图的实现
2019/11/21 Python
python爬虫线程池案例详解(梨视频短视频爬取)
2021/02/20 Python
Html5中的桌面通知Notification的实现
2018/09/25 HTML / CSS
纯html5+css3下拉导航菜单实现代码
2013/03/18 HTML / CSS
Under Armour安德玛法国官网:美国高端运动科技品牌
2018/06/29 全球购物
文秘专业应届生求职信范文
2013/11/14 职场文书
黄金酒广告词
2014/03/21 职场文书
访谈节目策划方案
2014/05/15 职场文书
交通文明倡议书
2014/05/16 职场文书
关于拾金不昧的感谢信
2015/01/21 职场文书
清明节网上祭英烈寄语2015
2015/03/04 职场文书
导游词之重庆钓鱼城
2019/09/19 职场文书
mysql字符串截取函数小结
2021/04/05 MySQL
Python实战之OpenCV实现猫脸检测
2021/06/26 Python
mysql数据库实现设置字段长度
2022/06/10 MySQL