Gulp前端构建工具
Gulp, 比Grunt更好用的前端构建工具
Gulp, 比Grunt更好用的前端构建工具
本文主要从两个方面介绍Gulp:一,Gulp相对于Grunt的优势; 二,Gulp的安装和使用流程
Gulp相对于Grunt的优势
gulp.js 的作者 Eric Schoffstall 在他介绍 gulp.js 的 presentation 中总结了 Grunt 的几点不足之处:
插件很难遵守单一责任原则。因为 Grunt 的 API 设计缺憾,使得许多插件不得不负责一些和其主要任务无关的事情。比如说要对处理后的文件进行更名操作,你可能使用的是
uglify
插件,也有可能使用的是concat
插件(取决于工作流的最后一个环节是谁)。我的看法:这或许是个问题,对很多人来说 Grunt 插件多少存在“职责不明”和“越俎代庖”的情况。在我看来,这也是 Grunt 一个设计思想:把对文件的操作抽象为一个独立的组件(Files),任何插件都以相同的规则来使用它。遗憾在于,使用它的过程发生在每个插件的独立配置对象里,所以总给人一种“把不该这个插件做的事情丢给它来做”的别扭感觉。
用插件做一些本来不需要插件来做的事情。因为 Grunt 提供了统一的 CLI 入口,子任务由插件定义,由 CLI 命令来调用执行,因此哪怕是很简单的外部命令(比如说运行
karma start
)都得有一个插件来负责封装它,然后再变成 Grunt CLI 命令的参数来运行,多此一举。我的看法:举双手双脚赞成!
试图用配置文件完成所有事,结果就是混乱不堪。规模较大,构建/分发/部署流程较为复杂的项目,其
Gruntfile
有多庞杂相信有经历的人都有所体会。而 gulp.js 奉行的是“写程序而不是写配置”,它走的是一种 node way。我的看法:对于 node.js 开发者来说这是好事,符合他们的一贯作风;不过对于那些纯前端工程师来说(数量不小),这似乎没有什么显著的改善。况且近来 Grunt 社区涌现了不少插件来帮助开发者组织/管理/简化臃肿的
Gruntfile
,效果都还不错。所以关于这一点,就见仁见智吧。落后的流程控制产生了让人头痛的临时文件/文件夹所导致的性能滞后。这是 gulp.js 下刀子的重点,也是本标题里“流式构建”所解决的根本问题。流式构建改变了底层的流程控制,大大提高了构建工作的效率和性能,给用户的直观感觉就是:更快。
我的看法:关于流式构建,短短几句话无法讲清它的来龙去脉,但是在 node.js 的世界里,
streaming
确实是至关重要的。我推荐一份阅读材料:Stream Handbook,读过之后相信心里就有数了。
作为对比和总结,作者列出了 gulp.js 的五大特点:
- 使用 gulp.js,你的构建脚本是代码,而不是配置文件;
- 使用标准库(node.js standard library)来编写脚本;
- 插件都很简单,只负责完成一件事-基本上都是 20 行左右的函数;
- 任务都以最大的并发数来执行;
- 输入/输出(I/O)是基于“流式”的。
Gulp的安装和使用流程
第一步:安装命令行工具
1
|
$ npm install -g gulp |
第二步:在你的项目下把 gulp 安装为开发依赖组件(假设你已经创建好了 package.json
)
$ cd <YOUR_PROJECT>
$ npm install gulp --save-dev
第三步:在项目的根路径下创建 Gulpfile.js
,初始内容为:
1
2
3
4
|
var gulp = require( 'gulp' ); gulp.task( 'default' , function () { }); |
第四步:运行!
1
2
3
4
|
var gulp = require( 'gulp' ); gulp.task( 'default' , function () { }); |
So far so good! 看起来和 Grunt 没差太远吧?的确如此,gulp.js 的学习曲线还是相当平缓的。接下来,为了能够顺利的编写构建脚本,我们来学习几个核心的 API 函数——别担心,gulp.js 的 API 非常简单,我们只需要了解四个就足以应对绝大多数的脚本编写了(而且用过 Grunt 的话,这四个都不是什么新鲜货)。
gulp.task(name[, deps], fn)
:注册任务name
是任务名称;deps
是可选的数组,其中列出需要在本任务运行要执行的任务;fn
是任务体,这是 gulp.js 的核心了,需要花时间吃透它,详情见此。gulp.src(globs[, options])
:指明源文件路径
用过 Grunt 的话,globs
一定不会陌生,这里没什么变化;options
是可选的,具体请查看 gulp.js APIgulp.dest(path)
:指明任务处理后的目标输出路径gulp.watch(glob[, options], tasks)/gulp.watch(glob[, options, cb])
:监视文件的变化并运行相应的任务。你没看错,watch
作为核心 API 出现在 gulp.js 里了,具体用法还是要多看文档,不过接下来我们会演示简单的例子。
范例
我们练习一个最常见的范例,写一个 node.js 程序时所需要的构建脚本。为此我们要做三件事情(括号内列出对应插件的名字,更多插件请到此处寻找):
- 语法检查 (
gulp-jshint
) - 合并文件 (
gulp-concat
) - 压缩代码 (
gulp-uglify
) - 文件重命名(
gulp-rename
)
另外,我们可能还需要文件更名操作,所以 gulp-rename
也会很有用。接着我们需要先在项目下安装这些插件:
1
|
$ npm install <PLUGIN_NAME> --save-dev |
最后我们完成所有任务的编写,完整的代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
var gulp = require( 'gulp' ); var jshint = require( 'gulp-jshint' ); var concat = require( 'gulp-concat' ); var uglify = require( 'gulp-uglify' ); var rename = require( 'gulp-rename' ); // 语法检查 gulp.task( 'jshint' , function () { return gulp.src( 'src/*.js' ) .pipe(jshint()) .pipe(jshint.reporter( 'default' )); }); // 合并文件之后压缩代码 gulp.task( 'minify' , function (){ return gulp.src( 'src/*.js' ) .pipe(concat( 'all.js' )) .pipe(gulp.dest( 'dist' )) .pipe(uglify()) .pipe(rename( 'all.min.js' )) .pipe(gulp.dest( 'dist' )); }); // 监视文件的变化 gulp.task( 'watch' , function () { gulp.watch( 'src/*.js' , [ 'jshint' , 'minify' ]); }); // 注册缺省任务 gulp.task( 'default' , [ 'jshint' , 'minify' , 'watch' ]); |
可以看出,基本上所有的任务体都是这么个模式:
1
2
3
4
5
6
7
|
gulp.task( '任务名称' , function () { return gulp.src( '文件' ) .pipe(...) .pipe(...) // 直到任务的最后一步 .pipe(...); }); |
非常容易理解!获取要处理的文件,传递给下一个环节处理,然后把返回的结果继续传递给下一个环节……直到所有环节完成。pipe
就是 stream
模块里负责传递流数据的方法而已,至于最开始的 return
则是把整个任务的 stream
对象返回出去,以便任务和任务可以依次传递执行。
或许写成这样会更直观:
1
2
3
4
5
6
7
8
|
gulp.task( 'task_name' , function () { var stream = gulp.src( '...' ) .pipe(...) .pipe(...) // 直到任务的最后一步 .pipe(...); return stream; }); |
至此,你已经可以使用 gulp.js 完成绝大多数的构建工作了。下一步,我也为你准备了几条建议:
- 花点时间浏览一下 gulp.js 插件库,大致了解下利用已有的插件你都可以做哪些事情
- 对于常用的插件,仔细阅读它们自己的文档,以便发挥出它们最大的功效
- 抽时间学习 gulp.js API,特别是
gulp.task()
里关于任务体的详细描述,学会如何执行回调函数(callback),如何返回promise
等等 - 尝试编写适合自己工作流程和习惯的任务,如果它工作良好,把它做成插件发布给大家吧!
Gulp前端构建工具的更多相关文章
- gulp 前端构建工具入门
gulp 前端构建工具入门 标签(空格分隔): gulp 1. 安装gulp npm i -g gulp 2. 创建gulp项目 2.1 Hello world 使用npm init初始化项目文件夹. ...
- gulp 前端构建工具使用
gulp 前端构建工具使用 1.新建一个web h5项目 2.准备好gulpfile.js文件 (1)下载链接:https://pan.baidu.com/s/116J-BaYOMRzeJW3i_J ...
- gulp前端构建工具的搭建
我的机器: 3.13.0-32-generic #57-Ubuntu SMP Tue Jul 15 03:51:08 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux 1 ...
- 入门gulp前端构建工具
1. 全局安装 gulp:(倘若之前电脑安装过,则跳过此步骤) $ cnpm install -g gulp 2. 作为项目的开发依赖(devDependencies)安装: (此步骤会自动在目录下创 ...
- 前端构建工具之gulp(一)「图片压缩」
前端构建工具之gulp(一)「图片压缩」 已经很久没有写过博客了,现下终于事情少了,开始写博吧 今天网站要做一些优化:图片压缩,资源合并等 以前一直使用百度的FIS工具,但是FIS还没有提供图片压缩的 ...
- 前端构建工具gulp使用
前端自动化流程工具,用来合并文件,压缩等. Gulp官网 http://gulpjs.com/ Gulp中文网 http://www.gulpjs.com.cn/ Gulp中文文档 https://g ...
- 前端构建工具gulp介绍
2016年3月3日 10:46:08 晴 前端构建工具gulpjs的使用介绍及技巧 gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常简 ...
- Gulp.js----比Grunt更易用的前端构建工具
Gulp.js----比Grunt更易用的前端构建工具 Grunt一直是前端构建工具,然而他也不是毫无缺陷的,gulp的作者 Eric Schoffstall 在他介绍 gulp.js 的 prese ...
- Gulp, 比Grunt更好用的前端构建工具
Gulp, 比Grunt更好用的前端构建工具 本文主要从两个方面介绍Gulp:一,Gulp相对于Grunt的优势: 二,Gulp的安装和使用流程 Gulp相对于Grunt的优势 gulp.js 的作者 ...
随机推荐
- Android.mk中的经常使用语法
Android.mk编译文件是用来向Android NDK描写叙述你的C,C++源码文件的, 今天查了一些经常使用的的语法. 一 概述: 一个Android.mk文件用来向编译系统描写叙述你的源码. ...
- Python 相机镜头
一哥第一卷感叹,这家奥地利~.这是什么g8事件,近盲目安装3g的OpenCV,结果徒劳. . . 入题.!环境Python2.7 严厉格按照什么步骤.必成功: 所需的软件如下面: VideoCaptu ...
- HDU 1505 City Game(01矩阵 dp)
Problem Description Bob is a strategy game programming specialist. In his new city building game the ...
- MVC中使用SignalR
MVC中使用SignalR打造酷炫实用的即时通讯功能附源码 前言,现在这世道写篇帖子没个前言真不好意思发出来.本贴的主要内容来自于本人在之前项目中所开发的一个小功能,用于OA中的即时通讯.由于当时 ...
- wordpress常见的问题
nginx如webserver,wordpress上传主题错误 413 Request Entity Too Large 解决: vim /usr/local/nginx/conf/nginx.con ...
- deepinmind(转)
http://it.deepinmind.com/ 花名有孚,支付宝工程师 有希望加入支付宝的同学,可以把简历发到我的个人邮箱spidercoco@gmail.com
- hdu 4975 最大流问题解决队伍和矩阵,利用矩阵dp优化
//刚開始乱搞. //网络流求解,假设最大流=全部元素的和则有解:利用残留网络推断是否唯一, //方法有两种,第一种是深搜看看是否存在正边权的环.见上一篇4888 //至少四个点构成的环,另外一种是用 ...
- AIX采用LV创ASM磁盘组
CREATE ASM ON AIX LV DEVICE OS:AIX 6100-03 ASM版本号 10205 # lspv hdisk0 000d295a6d68902b ...
- Oracle中的delete和truncate的关系
转自:http://chenxy.blog.51cto.com/729966/168459 1.相同点 a.都可以删除数据,其中truncate用于全表清空数据,而delete可以选择的删 ...
- asp.net学习之 数据绑定控件--表格绑定控件
原文:asp.net学习之 数据绑定控件--表格绑定控件 数据绑定 Web 服务器控件是指可绑定到数据源控件,以实现在 Web 应用程序中轻松显示和修改数据的控件.数据绑定 Web 服务器控件 ...