内容简介:用gulp-bufferify快速创建你的gulp插件
gulp-bufferify是我之前写的一个gulp插件,其实它没有实际的功能性用处,但是利用它可以快速实现一个gulp插件。举一个栗子:
import bufferify from 'gulp-bufferify' gulp.src('./**/*.txt') .pipe(bufferify(content => content.replace(/sam/g, 'tom'))) .pipe(gulp.dest('.'))
通过上面这段gulp代码,可以快速替换所有txt文档中的sam为tom。可以说,每一个gulp-bufferify就是一个插件,你可以利用它完成你想要的功能。
我们来看看他的使用方法:
let factory = (content, file, context, notifier) => {} bufferify(factory)
工厂函数factory有四个参数:
content
经过toString()的文档内容,一般在处理文本类型的文档时可以直接使用。
file
当前buffer的file,拥有file.path, file.contents, file.clone()等有用的信息。
context
管道中的上下文,相当于stream中的this。可以通过它实现文件的添加修改和删除。具体的话,你还得知道stream的相关知识。
notifier
用在异步处理中,通知生成器,使用方法如下:
.pipe(bufferify((content, file, context, notifier) => { let callback = notifier() setTimeout(() => callback(), 3000) }))
上面这段代码是异步处理的,当callback()执行时,stream才会进入下一个管道。
工厂函数的返回值应该是新的content,当你返回一个新的content的时候,这个buffer的内容就会被新的content替换(buffer文件是文本文件)。
而如果你返回的值为非真时,原始的content将被使用。
不过当你使用notifier的时候情况不同,执行notifier()就相当于告诉gulp-bufferify,你的插件将会以异步方式运行,所以这个时候你return的新的content将不会被采纳,知道你使用callback()。callback的使用方法和though2的callback使用方法是一样的,假如你修改了buffer文件,必须采用如下的形式:
.pipe(bufferify((content, file, context, notifier) => { let callback = notifier() let newcontent = content.replace('you', 'me') file.contents = new Buffer(newcontent) setTimeout(() => callback(null, file), 3000) }))
在gulp-bufferify中,真正改变stream的,主要是bufferify函数的返回值和context,返回新的content将改变file.contents,而使用context则可以在stream中新增文件。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 如何创建与框架无关的 JavaScript 插件
- 如何创建与框架无关的 JavaScript 插件
- MyBatis 的插件对象如何创建出来的
- Vue 2.0学习笔记:如何创建Vue插件
- 【第二篇】创建 @vue/cli3 插件,并整合 ssr 功能
- Flutter 实战之从 0 搭建「网易云音乐」App(一):创建项目、添加插件、通用代码
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据挖掘导论
Pang-Ning Tan, Michael Steinbach / 范明 范宏建 / 人民邮电出版社 / 2006-01-01 / 49.00元
本书全面介绍了数据挖掘的理论和方法,旨在为读者提供将数据挖掘应用于实际问题所必需的知识。本书涵盖五个主题:数据、分类、关联分析、聚类和异常检测。除异常检测外,每个主题都包含两章:前面一章讲述基本概念、代表性算法和评估技术,后面一章较深入地讨论高级概念和算法。目的是使读者在透彻地理解数据挖掘基础的同时,还能了解更多重要的高级主题。此外,书中还提供了大量示例、图表和习题。 本书适合作为......一起来看看 《数据挖掘导论》 这本书的介绍吧!