gulp入门

[转载](https://github.com/zhonglimh/Gulp

Gulp构建前端自动化工作流

Gulp构建前端自动化工作流:入门介绍及LiveReload的使用

其实这篇内容已躺在我的Evernote里许久,但一直搁置着,今天算是正式见光。

本文主要介绍如何使用Gulp.js,来帮助你构建一个自动化的前端开发流程。总结并归类自身使用中所遇到的方法、问题,便于新人上手和理解,同时也作为一份Gulp参考文档来使用,让你对Gulp有个更深入的了解。

最后,在正文开始前给新人提个醒:随着Gulp版本更新,API已发生了细小变化,目前网上很多文章,都是基于早期版本所写,当你查阅资料时一定要留意一下,否则会给你带来不少麻烦。

注:
本文所使用的工具版本为:Node.js(v0.10.21)、 Ruby(v2.2.1p85)、Gulp(v3.8.11)。
如有疑问欢迎在本文下方留言,或关注我的个人微信号:bluesdream_com

Gulp是什么鬼(What's Gulp) ?

Gulp是基于Node.js的一个构建工具(自动任务运行器),开发者可以使用它构建自动化工作流程(前端集成开发环境)。一些常见、重复的任务,例如:网页自动刷新、CSS预处理、代码检测、压缩图片、等等…… 只需用简单的命令就能全部完成。使用它,可以简化工作,让你把重点放在功能开发上;同时减少人为失误,提高开发效率和项目质量,让专注更为专注。如果你之前接触过Grunt,那上手Gulp就会觉得非常容易理解。

为什么使用Gulp而不使用Grunt(Why use Gulp instead of Grunt)?

构建前端自动化的工具有很多Grunt, Brunch, Broccoli…… 而目前过内最流行的属于Grunt,之前我也在用使用,那为什么选择Gulp来代替Grunt?

我简单的总结了以下3点:

  • 简洁:Gulp侧重“代码优于配置”(code over configuration)。最直观的感受,更为简单和清晰,不需要像Grunt一样写一堆庞大的配置文件。
  • 高效:Gulp基于Node Streams(流)来构建任务,避免磁盘反复I/O(读取/写入)。每个任务都是单独执行(坚持做一件事并且做好它),这使得它速度更快、更为纯粹。
  • 易学:Gulp核心API只有4个。简洁的API易于上手,学习过程比较平滑。

Gulp的核心API只有4个:src、dest、task、watch

  • gulp.src(globs[, options]):指明源文件路径
    globs:路径模式匹配;
    options:可选参数;
  • gulp.dest(path[, options]):指明处理后的文件输出路径
    path:路径(一个任务可以有多个输出路径);
    options:可选参数;
  • gulp.task(name[, deps], fn):注册任务
    name:任务名称(通过 gulp name 来执行这个任务);
    deps:可选的数组,在本任务运行中所需要所依赖的其他任务(当前任务在依赖任务执行完毕后才会执行);
    fn:任务函数(function方法);

  • gulp.watch(glob [, opts], tasks):监视文件的变化并运行相应的任务
    glob:路径模式匹配;
    opts:可以选配置对象;
    taks:执行的任务;

在我使用Gulp后,就明显感觉Grunt配置很是复杂。同样为了实现LiveReload功能,Gulp所需要的配置的代码,只有Grunt的一般都不到。具体可以参见我之前所写的一篇文章《Grunt插件之LiveReload 实现页面自动刷新,所见即所得编辑》与下文进行对比。

注:
1. streams(流)的简述:Node.js中的I/O操作是异步的,因此磁盘的读写和网络操作都需要传递回调函数。streams的优点:不需要把文件都一次性写入内存,通过pie(管道)把文件转为数据流(将任务和操作连接起来),像瀑布一样一级级(one by one)往下流(处理),因此只需一次I/O操作。而Grunt是每执行一个任务就需要I/O一次,在任务多的时候,就会有大量I/O操作,效率自然就会比较低。
2. 以前Gulp有5个核心API,但随着Gulp 3.5的更新,gulp.run()方法早已被弃用。

1. 安装Node.js(Install Node.js)

1.1 首先去Node.js官网,点击那个醒目的"INSTALL"按钮,下载并安装。

1.2 安装完成以后,打开命令行(Winkey+R -> 输入CMD)or(开始菜单 -> 所有程序 -> 选择命令提示符),执行以下2个简单的命令,查看Node.js是否已经安装正确:

node -v

查看 Node.js 版本号

npm -v

查看 npm 版本号

注:
现在的Node.js会自动安装npm(npm 是 Node.js 的包管理器,Gulp和Gulp插件就通过 npm 安装并管理)。

2. 创建项目目录(Create Project)

2.1 假设这个项目存放在D盘("D:\my-gulp"),我们首先进度D盘:

d:

2.2 然后进入文件夹:

cd my-gulp

3. Gulp安装(Installing Gulp)

3.1 全局安装:

npm install -g gulp

安装完成后,我们同样可以通过 gulp -v 命令,来查看Gulp的版本号。
这时项目文件夹中生成了一个node_modules文件夹,其里面就是对应的Gulp和Gulp插件。

注:
1. Gulp全局安装后,并不能像Grunt一样,只需安装一次就能在任何目下执行。他在每构建一个新项目时,都需要从这步骤开始再单独安装一次。
2. 至于为什么要这样,有人在stackoverflow上提出过疑问。得到的大致回复是为了更加灵活,因为有些插件基于特定的版本,这样做的话每个项目就等于都是独立的,互不影响。

3.2 本地安装:

npm install gulp --save-dev

注:
1. -g:代表全局安装;
2. --save:将保存配置信息至package.json(此文件在 node_modules\gulp 目录下)
3. -dev:将它作为你的项目依赖添加到中devDependencies内(--save和-dev是2个东西,记得分清前面的"-"号)
4. 由于Gulp会自带package.json文件(用于存储项目的元数据),所以这里只做简单介绍(如果你想自己创建,也可通过命令 npm init,然后根据引导填写相关信息):

{
     "name": "gulp", // 模块名称:只能包含小写字母数字和中划线,如果为空则使用项目文件夹名称代替(必填)
     "version": "3.8.11", // 版本号(必填)
     "description": "The streaming build system", // 描述:会在npm搜索列表中显示(必填)
     "homepage": "http://gulpjs.com", // 项目主页
     "repository": { // 资源库
           "type": "git",
           "url": "git://github.com/gulpjs/gulp"
     },
          "author": { // 作者信息
                "name": "Ryan",
                "email": "contact@bluesdream.com",
                "url": "http://www.bluesdream.com/"
     },
          "licenses": [{ // 开源协议
               "type": "MIT",
               "url": "https://raw.githubusercontent.com/gulpjs/gulp/master/LICENSE"
          }],
          "devDependencies": { // 这里面的参数,指定了项目依赖的Gulp和Gulp插件版本。
                "gulp": "^3.8.11"
     }
}

4. Gulp插件安装(Install Gulp Plugins)

接着安装我们所需要的插件,这里,我们通过gulp-livereload + gulp-webserver,来实现页面自动刷新:

静态服务器( gulp-webserver
网页自动刷新( gulp-livereload

npm install gulp-livereload gulp-webserver --save-dev

5. Gulp任务配置(Task Configuration)

5.1 在项目根目录中,创建gulpfile.js文件,用来配置和定义任务(task)。

5.2 打开Gulpfile.js文件中,填写相关配置:

// 引入gulp
var gulp = require('gulp');             // 基础库

// 引入gulp插件
var livereload = require('gulp-livereload'), // 网页自动刷新(服务器控制客户端同步刷新)
    webserver = require('gulp-webserver'); // 本地服务器

// 注册任务
gulp.task('webserver', function() {
    gulp.src( './' ) // 服务器目录(./代表根目录)
    .pipe(webserver({ // 运行gulp-webserver
        livereload: true, // 启用LiveReload
        open: true // 服务器启动时自动打开网页
    }));
});

// 监听任务
gulp.task('watch',function(){
    gulp.watch( '*.html', ['html']) // 监听根目录下所有.html文件
});

// 默认任务
gulp.task('default',['webserver','watch']);

5.2.1 执行默认:

gulp

看到如下提示说明执行成功:

[18:19:24] Using gulpfile D:\my-gulp\gulpfile.js
[18:19:24] Starting 'webserver'...
[18:19:24] Webserver started at http://localhost:8000
[18:19:24] Finished 'webserver' after 10 ms
[18:19:24] Starting 'watch'...
[18:19:24] Finished 'watch' after 97 ms

想要终止任务,只需Ctrl+c根据提示输入y便能终止,或直接关闭命令提示符。

5.2.2 执行特定任务:

grunt webserver

看到如下提示说明执行成功:

[18:21:56] Using gulpfile D:\my-gulp\gulpfile.js
[18:21:56] Starting 'webserver'...
[18:21:56] Webserver started at http://localhost:8000
[18:21:56] Finished 'webserver' after 10 ms

至此,你已轻松学会如何使用Gulp,并对它有一个大致的了解。

注:
1. Gulp插件可以通过Gulp官网npm官网Browsenpm 上找到你所要的插件。
2. 不要在node_modules文件夹内手动删除插件,请使用命令卸载。因为手动删除的只是下载插件包,但package.jason中的配置信息并没有清除。
3. 不要直接移动Gulp插件,否则由于系统层级限制,出现错误提示“文件名对目标文件夹可能过长。您可以缩短文件名并重试,或者尝试路径较短的位置。”。此时把文件夹打包成RAR后再操作便可。
4. npm常用命令:
安装插件:npm <module> [-g] [--save-dev]
更新插件:npm update <module> [-g] [--save-dev]
卸载插件:npm uninstall <module> [-g] [--save-dev]
指定版本:npm install <module>@VERSION [--save-dev] (其中VERSION就是你所需要的版本号)

参考资料:
Building With Gulp
Introduction to Gulp.js – Code Over Configuration
An introduction to Gulp

扩展资料:
Gulp API docs
gulp-cheatsheet

原文地址:Gulp构建前端自动化工作流之:入门介绍及LiveReload的使用

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容

  • [转载](https://github.com/zhonglimh/Gulp) Gulp构建前端自动化工作流 Gu...
    Gopal阅读 382评论 0 1
  • 简介:gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器;她不仅能对网站资源进行优化,而且在开发...
    情怀水岸阅读 823评论 0 5
  • Gulp简介 最近流行前端构建工具,苦于之前使用Grunt,代码很难阅读,现在出了Gulp,真是摆脱了痛苦。发现了...
    小k博客阅读 801评论 4 19
  • 觉得此文甚好,转发来自[http://w3ctrain.com/2015/12/22/gulp-for-begin...
    Tinazbh阅读 462评论 0 0
  • 一般会认为,发泄愤怒有减少愤怒和使我感觉更好的作用。实验表明:发泄愤怒会使人更愤怒,会使人有更坚固愤怒的态度并建立...
    sxrunn阅读 407评论 0 1