当然,gulp不仅仅能转换Sass,这里会提到如下转换:

  1. jsx转换成常规的JavaScript(说到jsx,玩过react的同学应该是知道的)
  2. es6转换为es5
  3. Less,Sass转换为CSS
  首先,新建一个文件夹,然后继续和之前的方法一样,在文件夹里npm init , npm install --save-dev gulp
  安装好了gulp之后,我们还需要安装几个用来代码转换的插件,对应关系如下:
jsx代码转换   npm install gulp-react
es6代码转换 
 npm install gulp-babel , npm install babel-preset-es2015   
   (其实es6也叫es2015)
less代码转换 npm install gulp-less
sass代码转换   npm install gulp-sass
 
tips:如果npm装的很慢或者卡进度了,可以换用cnpm.
 
 
首先是jsx和es6的转换:
好的,准备工作结束,我们先来建一个src目录,在目录下新建一个js文件,写入一些jsx和es6的代码:
 
  1. 'use strict';
  2. const react = require('react');
  3. class MYTEST extends react.Component{
  4. constructor(props){
  5. //noinspection JSAnnotator
  6. super(props);
  7. }
  8. render(){
  9. return (
  10. <div>gulp react ,jsx to js and es6 to es5.</div>
  11. )
  12. }
  13. }

接下来在项目根目录下来新建出我们的主角——gulpfile.js,写入代码如下:

  1. var gulp = require('gulp');
  2. var react = require('gulp-react');
  3. var babel = require('gulp-babel');
  4. var less = require('gulp-less');
  5. var sass = require('gulp-sass');
  6. gulp.task("default",function () {
  7. return gulp.src('./src/jsxAndEs6.js') //要转换的文件
  8. .pipe(react())  //转换jsx代码
  9. .pipe(babel({
  10. presets:['babel-preset-es2015']    //插件数组
  11. }))  //es6转es5
  12. .pipe(gulp.dest('./dest'));//转换后的文件输出到这里
  13. })

注意:这里引入库的时候,并没有引入我们用npm安装的babel-preset-es2015,因为他是作为babel进行转换时的一个插件参数存在的,直接在babel中调用即可

接下来运行gulp指令,会发现目录的dest目录下,多了一个我们转换后的js文件,打开转换后的代码,惨不忍睹啊:

到这里呢,jsx和es6的转换就搞定了。

接下来是Less和Sass:

首先在src目录下新建一个less文件,代码如下:

  1. @color:#aaa;
  2. .container{
  3. color:@color;
  4. }

再新建一个sass文件,代码如下:

  1. $fontStack:    Helvetica, sans-serif;
  2. $primaryColor: #333;
  3. body {
  4. font-family: $fontStack;
  5. color: $primaryColor;
  6. }

接下来回到我们的gulpfile.js,添加转换sass和less的task:

  1. var gulp = require('gulp');
  2. var react = require('gulp-react');
  3. var babel = require('gulp-babel');
  4. var less = require('gulp-less');
  5. var sass = require('gulp-sass');
  6. gulp.task('less',function () {
  7. return gulp.src('./src/Less_style.less')
  8. .pipe(less())
  9. .pipe(gulp.dest('./dest'));
  10. });
  11. gulp.task('sass',function () {
  12. return gulp.src('./src/Sass_style.scss')
  13. .pipe(sass())
  14. .pipe(gulp.dest('./dest'))
  15. })
  16. gulp.task("default",['less','sass'],function () {
  17. return gulp.src('./src/jsxAndEs6.js') //要转换的文件
  18. .pipe(react())  //转换jsx代码
  19. .pipe(babel({
  20. presets:['babel-preset-es2015']    //插件数组
  21. }))  //es6转es5
  22. .pipe(gulp.dest('./dest'));//转换后的文件输出到这里
  23. });

注意,写了新的task之后,一定要引入到default中哦,不然不会执行的。

接下来在命令行执行gulp指令,会发现dest文件夹下多出了编译后的css文件,效果如下:

大功告成~~

gulp入坑系列(4)——gulp的代码转换的更多相关文章

  1. gulp入坑系列(2)——初试JS代码合并与压缩

    在上一篇里成功安装了gulp到项目中,现在来测试一下gulp的合并与压缩功能 gulp入坑系列(1)--安装gulp(传送门):http://www.cnblogs.com/YuuyaRin/p/61 ...

  2. gulp入坑系列(1)——安装gulp

    前言   好吧,我承认我是为了搞定Sass编译CSS文件的问题,迷一样的着手入gulp的坑,sass和gulp的爬坑历程大概会一起更新.然后感觉这里windows和mac的流程差不多,不过mac的通常 ...

  3. gulp入坑系列(3)——创建多个gulp.task

    继续gulp的爬坑路,在准备get更多gulp的具体操作之前,先来明确一下在gulp中创建和使用多个task任务的情况. gulp所要做的操作都写在gulp.task()中,系统有一个默认的defau ...

  4. 3-STM32带你入坑系列(自己封装点亮一个灯的库--Keil)

    2-STM32带你入坑系列(点亮一个灯--Keil) 首先建一个stm32f103x.h的文件,然后 #include "stm32f103x.h" 还记得上一节 现在呢就是做一个 ...

  5. 2-STM32带你入坑系列(点亮一个灯--Keil)

    1-STM32带你入坑系列(STM32介绍) 首先是安装软件 这一节用Kei来实现,需要安装MDK4.7这个软件,怎么安装,自己百度哈.都学习32的人了,不会连个软件都不会安装吧....还是那句话 没 ...

  6. 1-STM32带你入坑系列(STM32介绍)

    由于自己的物联网开发板上的单片机是用的STM32,但是有些朋友没有用过,所以我将用这块开发板,带着大家入门STM32 先介绍一下STM32,我是在大三下学期的时候开始接触STM32,当时是想做一个小车 ...

  7. 入坑第二式 golang入坑系列

    史前必读: 这是入坑系列的第二式,如果错过了第一式,可以去gitbook( https://andy-zhangtao.gitbooks.io/golang/content/ )点个回放,看个重播.因 ...

  8. Docker入坑系列(二)

    Docker入坑系列(二) 上一篇我们为Docker创造了一个良好的生活环境,这一篇我们就开始让Docker活起来. 安装Docker ok,原文地址在这里. 当然,我只是自己翻译了一下而已- -跟着 ...

  9. Docker入坑系列(一)

    Docker入坑系列(一) 引用嘛,当然是来引用别人说的东西啦. Docker 是一个开源项目,诞生于 2013 年初,它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linux ...

随机推荐

  1. AX 与Citrix打印机问题

    国外文章,抄个链接,备查 http://blogs.msdn.com/b/axsupport/archive/2010/07/06/ax-2009-citrix-amp-terminal-server ...

  2. java实现二叉树查找树

    二叉树(binary)是一种特殊的树.二叉树的每个节点最多只能有2个子节点: 二叉树 由于二叉树的子节点数目确定,所以可以直接采用上图方式在内存中实现.每个节点有一个左子节点(left childre ...

  3. html5[1]:优化Android Webview性能

    尽量少用position:relative 做一个OTO项目时,页面上下滑动时,颤抖的很厉害: 页面中主要是图片比较多,开始以为是图片多的原因,但是把所有图片都不加载,还是颤抖: 后来,去掉所有外部的 ...

  4. 一个简单的 ASP.NET MVC 例子演示如何在 Knockout JS 的配合下,使用 TypeScript 。

    前言 TypeScript 是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程.安德斯·海尔斯伯格,C#的首席架 ...

  5. Unity 坐标系

    Unity 使用的是左手坐标系

  6. 配置visual studio code进行asp.net core rc2的开发

    1.安装.net core sdk https://github.com/dotnet/cli#installers-and-binaries,根据你的系统选择下载. 2.下载vscode的C#扩展插 ...

  7. NoSuchMethodError: antlr.collections.AST.getLine()I

    错误完整表述: Filter execution threw an exception] with root cause java.lang.NoSuchMethodError: antlr.coll ...

  8. SQL中对XML的处理

    DECLARE  @PreSOMasterXML XMLDECLARE   @SDA VARCHAR(100)SET @PreSOMasterXML=N'<ProcessTaskRequest& ...

  9. BAT及各大互联网公司前端笔试面试题--Html,Css篇

    注意 转载须保留原文链接(http://www.cnblogs.com/wzhiq896/p/5931347.html )作者:wangwen896 整理分享出来希望更多的前端er共同进步吧,不仅适用 ...

  10. [CLR via C#]15. 枚举类型和位标志

    一.枚举类型 枚举类型(enumerated types)定义了一组"符号名称/值"配对. 例如,以下Color类型定义了一组符号,每个符号都标识一种颜色: internal en ...