如何编写一个gulp插件
来源:互联网 发布:性别歧视 知乎 编辑:程序博客网 时间:2024/06/06 01:02
很久以前,我们在"细说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高级技巧
0 0
- 如何编写一个gulp插件
- 如何编写一个gulp插件
- 如何编写一个gulp插件
- 如何编写一个gulp插件
- 如何编写一个Jquery插件
- popcornmaker 下面如何编写一个插件
- gulp---gulp常用插件
- gulp-usemin <gulp插件>
- gulp插件/gulp模块
- gulp.spritesmith <gulp插件>
- gulp.order <gulp插件>
- gulp-filter <gulp插件>
- gulp 插件
- gulp插件
- gulp 插件
- gulp插件
- 编写一个webpack插件
- 如何编写lighttpd插件
- php无限极分类
- java数据类型转换____request请求参数类型转换
- 二分查找法-求解x次幂
- 图片压缩——压缩图片让你的效率更高
- 手把手教你写电商爬虫-第五课 京东商品评论爬虫 一起来对付反爬虫
- 如何编写一个gulp插件
- Android实用插件,持续更新
- window.onload用法详解
- Deep memory network 框架
- 《我的互联网方法论》
- numpy教程:数组操作
- python发邮件
- Qt修改工程目录后出现Qt Starting executable failed: [Path]:Success错误
- Android与Javascript交互