当前位置: 移动技术网 > IT编程>开发语言>Java > 如何编写javascript的gulp插件

如何编写javascript的gulp插件

2019年07月22日  | 移动技术网IT编程  | 我要评论

很久以前,我们在"细说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]、

[2]、

[3]、

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网