《移动Web前端高效开发实战》笔记2——使用Gulp构建一个ECMAScript 6和Sass应用

8.3.1 安装及布局

运转Gulp需要Node.js环境,请参见第二段内容搭建Node.js环境。使用NPM全局安装Gulp,命令如下:

npm install gulp-cli –g

然后,在类型根本目录下创造package.json文件,命令如下:

npm init

据悉指引配置型信息。然后安装Gulp依赖包,命令如下:

npm install gulp –save-dev

于类型根目录下,创建gulpfile.js文件,内容如下:

var gulp = require("gulp");

gulp.task("default", function(){                     // 定义名称为“default”的任务

         console.log("thisis default task");       // 此处定义default任务处理过程。

});

跟Grunt相似,Gulp将构建过程拆解为一个个独的分任务,使用gulp.task方法定义任务。通过命令提示符进入到品种目录,用“gulp
任务名”执行任务,实例命令如下:

gulp default

提示:对于默认(default)任务,可以省任务名。

每当创立任务之时节,和Grunt相似,可以指定任务的凭项,代码如下:

gulp.task(“main”, [“deps1”, “deps2”, …],function(){

         // 相关执行

});

gulp.task方法的老二单参数(数组)为“main”任务的因项。

品类中日常根据需要将构建过程拆解为多独稍任务。下面介绍如何具体定义。

首先,指定要构建的情,并由此Gulp插件来成功构建,最终输出到指定的目录。

动gulp.src方法指定文件源,代码如下:

gulp.src(“src/**/*.js”);:

// 或者 对于多个目录下的根源,可以动用数组

gulp.src([“src/**/*.js”, “theme/**/*.scss”]);

gulp.src方法返回Stream对象,可以由此pipe方法以内容传递让插件。所有插件都领pipe传递过来的数目,处理多少允许链式调用,代码如下:

gulp.src(“src/**/*.js”).pipe(plugin1()).pipe(plugin2())…

构建了后,需要利用gulp.dest方法以数据保存到文件被,代码如下:

gulp.src(“src/**/*.js”).pipe(gulp.dest(“dist”));       // 读取src下的所有js,写入到dist目录下

Gulp的每次操作都返回流对象,所有操作以内存中展开,不需要操作磁盘,从而大幅提高了构建速度。

8.3.2 预处理任务

直达一致节约吃,介绍了Gulp的安装,配置,以及Grunt任务之定义及实践。本节以介绍编译ECMAScript
6、Sass和CSS Sprite任务。

“gulp-babel”插件可以拿ECMAScript 6胡编译为ECMAScript
5。以便运行于未支持ECMAScript 6的浏览器上。首先安装该插件,命令如下:

npm install gulp-babel –save-dev

npm install babel-preset-es2015  --save-dev

然后,在gulpfile.js文件被开创任务,代码如下:

var babel = require("gulp-babel");      // 引入babel

gulp.task("compile-js", function(){

         gulp.src("src/**/*.js")                    // 处理src下的所有js脚本

                   .pipe(babel({                       // 调用babel

                            presets:['es2015']     // 采用es2015预设插件,将脚本编译为ECMAScript 5

                   }))

                   pipe(gulp.dest("dist/js"));   // 编译好的内容保存到dist目录下的js目录

});

Babel可以拿JavaScript文件,甚至React的JSX文件编译为标准的JavaScript文件。Babel官方提供的预设插件(presets)让用户会又简短地采用Babel。presets是针对性特定编译条件预设的一致组插件集合。如仍实例中,采用的es2015预设插件包含插件有“check-es2015-constants”,“transform-es2015-arrow-functions”等。

顾:Babel只是做了语法层次之易,并无会见加API的支持。对于class关键字定义之近乎,Babel会将那个转会为经过prototype定义之靶子。而对于ECMAScript
6的Promise对象,Babel不会见做另外处理,因此要经polyfill来针对浏览器不支持的API进行扩张。如“es6-promise”使得浏览器支持Promise对象。

以实质上的类面临,可以于干净目录下创办的“.babelrc”文件中安排Babel,代码如下:

{

         "presets":["es2015"]

}

编译Sass文件可以应用gulp-sass插件,安装命令如下:

npm install gulp-sass –save-dev

然后,在gulpfile.js文件被,增加任务尽Sass编译,代码如下:

var sass = require("gulp-sass");                            // 引入sass插件

gulp.task("compile-sass", function(){                   // 定义编译sass的任务

         gulp.src("theme/**/*.scss")                            // 处理theme下的所有的sass文件

         .pipe(sass().on('error',sass.logError))        // 采用sass插件编译,并处理错误

         .pipe(gulp.dest("dist/css"));                           // 编译好的内容输出到dist目录下的css目录

});

在品种中,为了优化加载性能,需要以小图合成一布置大图,也不怕是所谓的“CSS
Sprites”。该意义下gulp.spritesmith插件来兑现,安装命令如下:

npm install gulp.spritesmith –save-dev

下一场于gulpfile.js文件中成立任务,代码如下:

var spritesmith = require('gulp.spritesmith');                // 引入sprite插件

gulp.task("sprite", function () {                                         // 定义任务

         gulp.src("theme**.png")                          // 处理theme目录下的png文件

                   .pipe(spritesmith({                                          // 调用插件合并图片

                            imgName:'sprite.png',                         // 输出合成的图片名称

                            cssName:'sprite.css'                            //输出对应的css文件

                   }))

                   .pipe(gulp.dest("dist"));                                  // 输出到dist目录

});

 

本节介绍了三独先行处理工具,有gulp-babel,gulp-sass和gulp.spritesmith。

 

重多信息关注:

图片 1