欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

如何编写javascript的gulp插件

程序员文章站 2024-03-08 09:53:34
很久以前,我们在"细说gulp"随笔中,以压缩javascript为例,详细地讲解了如何利用gulp来完成前端自动化。 再来短暂回顾下,当时除了借助gulp之外,我们还利...

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

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

代码如下:

如何编写javascript的gulp插件

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

正文

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

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

如下:

如何编写javascript的gulp插件

下面我们将利用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]、gulp高级技巧

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