如何编写javascript的gulp插件
程序员文章站
2024-03-08 09:53:34
很久以前,我们在"细说gulp"随笔中,以压缩javascript为例,详细地讲解了如何利用gulp来完成前端自动化。
再来短暂回顾下,当时除了借助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]、
[2]、
[3]、gulp高级技巧
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
上一篇: Java8中使用流方式查询数据库的方法
下一篇: Unicode中文转码函数代码