Gulp task 任务重构

🌙
手机阅读
本文目录结构

任务重构

当一个组合操作执行时,这个组合中的每一个任务每次被调用时都会被执行。

例如,在两个不同的任务(task)之间调用的 clean 任务(task)将被执行两次,并且将导致不可预期的结果。

因此,最好重构组合中的 clean 任务(task)。

如果你有如下代码:

// This is INCORRECT
const { series, parallel } = require('gulp');
const clean = function(cb) {
  // body omitted
  console.log('clean');
  cb();
};
const css = series(clean, function(cb) {
  // body omitted
  console.log('css');
  cb();
});
const javascript = series(clean, function(cb) {
  // body omitted
  console.log('javascript');
  cb();
});
exports.default = parallel(css, javascript);

重构为:

const { series, parallel } = require('gulp');
function clean (cb) {
    // body omitted
    console.log('clean');
    cb();
}
function css (cb) {
    // body omitted
    console.log('css');
    cb();
}
function javascript (cb) {
    // body omitted
    console.log('javascript');
    cb();
}
exports.default = series(clean, parallel(css, javascript));

https://a.axihe.com/npm/gulp/WX20200614-180634.png

任务可以嵌套任意深度

series()parallel() 可以被嵌套到任意深度。

const { series, parallel } = require('gulp');

function clean(cb) {
  // body omitted
  cb();
}

function cssTranspile(cb) {
  // body omitted
  cb();
}

function cssMinify(cb) {
  // body omitted
  cb();
}

function jsTranspile(cb) {
  // body omitted
  cb();
}

function jsBundle(cb) {
  // body omitted
  cb();
}

function jsMinify(cb) {
  // body omitted
  cb();
}

function publish(cb) {
  // body omitted
  cb();
}

exports.default = series(
  clean,
  parallel(
    cssTranspile,
    series(jsTranspile, jsBundle)
  ),
  parallel(cssMinify, jsMinify),
  publish
);

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了