走进gulp4的世界

更多内容欢迎来到博客:https://imjianjian.github.io

gulp简介

  • 自动化 - gulp是一个工具包,可帮助您在开发工做流程中自动执行痛苦或耗时的任务。
  • 与平台无关 - 集成被集成到全部主流IDE中,人们正在使用PHP,.NET,Node.js,Java和其余平台。
  • 强大的生态系统 - 使用npm模块作任何你想要的,拥有超过2000个插件进行流文件转换。
  • 简单 - 仅提供最少的API,易于学习和使用简单。 用gulp对本身的描述就是:Automate and enhance your workflow。

安装

要使用gulp要保证你的电脑上要有node环境html

官方建议你这么安装它node

//全局安装gulp命令行
$ npm install gulp-cli -g

//gulp4.0
$ npm install gulp@next -D

//gulp3.9.1
$ npm install gulp -D 

//建立gulpfile.js文件
$ touch gulpfile.js
$ gulp --help
复制代码

更新

  • 新的任务系统(基于 bach,替换掉了原先基于 orchestrator 的任务系统)
  • 移除 gulp.reset
  • gulp.task 再也不支持三个参数的用法
  • gulp.task 用字符串注册的任务必须是直接在命令行中调用的任务
  • gulp.task 能够接受单参数语法,这个参数必须是一个命名函数,函数名会被做为任务名
  • 添加了 gulp.series 和 gulp.parallel 方法用于组合任务
  • 添加了 gulp.tree 方法用于获取任务树,传入 { deep: true } 参数能够获得一个 archy 兼容的节点列表
  • 添加了 gulp.registry 方法以定制注册表。
  • 添加了 gulp.symlink 方法,功能和 gulp.dest 一致,不过是以软连接的方式
  • gulp.dest 和 gulp.symlink 方法添加了 dirMode 参数容许对目标目录更好地控制
  • gulp.src 接收的文件匹配字符串会顺序解释,因此你能够写成这样 gulp.src(['.js', '!b.js', 'bad.js'])(排除全部以 b 开头的 JS 文件可是除了 bad.js)
  • gulp.src 方法添加了 since 选项,筛选在特定时间点以后修改过的文件(用于增量编译)
  • 将命令行分离出来成为一个独立模块,以便节约带宽/空间。用 npm install gulp -g 或 npm install gulp-cli -g 均可以安装命令行,只是 gulp-cli 不包含模块代码因此比较小
  • 命令行添加了 --tasks-json 参数,能够导出整个任务树以供他用
  • 命令行添加了 --verify 参数用以检查 package.json 中是否包含黑名单插件(违背准则而被禁入官方插件列表的可怜娃们)。

API

gulp4在gulp3的基础上新增了几个函数,但它的使用依旧简单方便。一共以下10个:git

  • gulp.src() --全局匹配一个或多个文件
  • gulp.dest() --将文件写入目录
  • gulp.symlink() --与dest类似,可是使用软链接形式
  • gulp.task() --定义任务
  • gulp.lastRun() --得到上次成功运行的时间戳
  • gulp.parallel() --并行运行任务
  • gulp.series() --运行任务序列
  • gulp.watch() --当文件发生变化时作某些操做
  • gulp.tree() --得到任务书树
  • gulp.registry() --得到或注册任务

官方说明API说明:https://github.com/gulpjs/gulp/blob/master/docs/API.mdgithub

task(parallel and series)

gulp4再也不可以经过数组形式传入任务,你须要使用gulp.series()和gulp.parallel()来执行他们。例如:npm

gulp.task('default',gulp.parallel('taskA','taskB'));//并行执行
gulp.task('default',gulp.series('taskA','taskB'));//按顺序执行
复制代码

parallel和series函数能够接受函数做为参数,这意味着咱们能够将任务用独立函数表示:json

funcion taskA(){...}
funcion taskB(){...}

gulp.task(taskA);//最简单的方式
gulp.task('i-am-taskB',taskB);//为taskB添加任务名
gulp.task('taskA-taskB', gulp.series(taskA, taskB));//序列执行
gulp.task('taskA-taskB', gulp.parallel(taskA,taskB));//并行运行
复制代码

并且当咱们执行序列化任务时,面板的输出也更加清晰gulp

PS D:\github\resume> gulp
[21:49:59] Using gulpfile D:\project\gulpfile.js
[21:49:59] Starting 'default'...
[21:49:59] Starting 'copyfile'...
[21:49:59] Finished 'copyfile' after 90 ms
[21:49:59] Starting 'minifyhtml'...
[21:49:59] Finished 'minifyhtml' after 171 ms
[21:49:59] Starting 'minifyCSS'...
[21:50:00] Finished 'minifyCSS' after 353 ms
[21:50:00] Starting 'uglyfyJS'...
[21:50:01] Finished 'uglyfyJS' after 1.43 s
[21:50:01] Finished 'default' after 2.05 s
复制代码

gulp.lastRun()

语法:
gulp.lastRun(taskName,timeResolution)
参数:
taskName:任务名
timeResolution(可选):返回的时间戳的精度
复制代码

例如数组

gulp.lastRun('someTask', 1000) // 1426000004000.
gulp.lastRun('someTask', 100) // 1426000004300.
复制代码

gulp.tree()

语法:
gulp.tree(option)
options:
{
    deep:true/false //是否遍历每一个子任务
}
复制代码

示例gulpfile.jsbash

gulp.task('one', function(done) {
  // do stuff
  done();
});

gulp.task('two', function(done) {
  // do stuff
  done();
});

gulp.task('three', function(done) {
  // do stuff
  done();
});

gulp.task('four', gulp.series('one', 'two'));

gulp.task('five',
  gulp.series('four',
    gulp.parallel('three', function(done) {
      // do more stuff
      done();
    })
  )
);
复制代码

实例输出函数

gulp.tree()

// output: [ 'one', 'two', 'three', 'four', 'five' ]

gulp.tree({ deep: true })

/*output: [
   {
      "label":"one",
      "type":"task",
      "nodes":[]
   },
   {
      "label":"two",
      "type":"task",
      "nodes":[]
   },
   {
      "label":"three",
      "type":"task",
      "nodes":[]
   },
   {
      "label":"four",
      "type":"task",
      "nodes":[
          {
            "label":"<series>",
            "type":"function",
            "nodes":[
               {
                  "label":"one",
                  "type":"task",
                  "nodes":[]
               },
               {
                  "label":"two",
                  "type":"task",
                  "nodes":[]
               }
            ]
         }
      ]
   },
   {
      "label":"five",
      "type":"task",
      "nodes":[
         {
            "label":"<series>",
            "type":"function",
            "nodes":[
               {
                  "label":"four",
                  "type":"task",
                  "nodes":[
                     {
                        "label":"<series>",
                        "type":"function",
                        "nodes":[
                           {
                              "label":"one",
                              "type":"task",
                              "nodes":[]
                           },
                           {
                              "label":"two",
                              "type":"task",
                              "nodes":[]
                           }
                        ]
                     }
                  ]
               },
               {
                  "label":"<parallel>",
                  "type":"function",
                  "nodes":[
                     {
                        "label":"three",
                        "type":"task",
                        "nodes":[]
                     },
                     {
                        "label":"<anonymous>",
                        "type":"function",
                        "nodes":[]
                     }
                  ]
               }
            ]
         }
      ]
   }
]
*/
复制代码

gulp-load-plugins

这是一个用于自动加载插件的gulp插件,安装以下:

npm install gulp-load-plugins -D
复制代码

当一个项目须要不少插件来管理的时候,你的gulpfile.js可能会变成这样:

var gulp = require('gulp'),
    a = require('gulp-a'), 
    b = require('gulp-b'),
    c = require('gulp-c'),
    ...
    ...
    z = require('gulp-z');  
复制代码

使用gulp-load-plugins可让你少写一些重复代码,你能够这样使用:

var gulp = require('gulp');
//加载gulp-load-plugins插件,并立刻运行它
var plugins = require('gulp-load-plugins')();
//或是:
//var gulpLoadPlugins = require('gulp-load-plugins');
//var plugins = gulpLoadPlugins();
复制代码

调用插件

plugins.clone() //等价于require('gulp-clone')();
复制代码

实质上是gulp帮助咱们作了以下操做

plugins.clone= require(‘gulp-clone’); 
复制代码
相关文章
相关标签/搜索