如何编写javascript的gulp插件

很久以前,我们在"细说gulp"随笔中,以压缩JavaScript为例,详细地讲解了如何利用gulp来完成前端自动化。

再来短暂回顾下,当时除了借助gulp之外,我们还利用了第三方gulp插件”gulp-uglify”,来达到压缩JavaScript文件的目的。

代码如下:

今儿,我们的重点就是,自己也来实现一个gulp插件。

正文

其实,如果只是单纯地想要编写一个gulp插件不难,可以借助through2或者through-gulp来编写(through-gulp是基于through2开发的)。

例如,我们想要接下来即将编写的插件(暂取名为modify),实现这样的功能:将指定html文件中的{{…}},全部替换成'Monkey 2 Dorie'。

如下:

下面我们将利用through2以及through-gulp一一道来。

**through2**

'use strict'

var through2 = require('through2');

module.exports = modify;

function modify(){

return through2.obj(function(file, encoding, cb){

//如果文件为空,不做任何操作,转入下一个操作,即下一个pipe

if(file.isNull()){

console.log('isNull');

this.push(file);

return cb();

}

//插件不支持对stream直接操作,抛出异常

if(file.isStream()){

console.log('isStream');

this.emit('error');

return cb();

}

//内容转换,处理好后,再转成Buffer形式

var content = versionFun(file.contents.toString());

file.contents = new Buffer(content);

//下面这两句基本是标配,可参考through2的API

this.push(file);

cb();

});

}

function versionFun(data){

return data.replace(/{{something}}/, ' Monkey 2 Dorie ');

}

**through-gulp**

'use strict'

var through = require('through-gulp');

module.exports = modify;

function modify(){

var stream = through(function(file, encoding, callback){

//如果文件为空,不做任何操作,转入下一个操作,即下一个pipe

if(file.isNull()){

console.log('file is null!');

this.push(file);

return callback();

}

//插件不支持对stream直接操作,抛出异常

if(file.isStream()){

console.log('file is stream!');

this.emit('error');

return callback();

}

//内容转换,处理好后,再转成Buffer形式

var content = versionFun(file.contents.toString('utf-8'));

file.contents = new Buffer(content, 'utf-8');

this.push(file);

callback();

}, function(callback){

console.log('处理完毕!');

callback();

});

return stream;

}

function versionFun(data){

return data.replace(/{{something}}/, ' Monkey 2 Dorie ');

}

详情代码见github.

拓展阅读

[1]、through-gulp

[2]、gulp规范

[3]、gulp高级技巧

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!

以上是 如何编写javascript的gulp插件 的全部内容, 来源链接: utcz.com/p/211522.html

回到顶部