我一直试图自己解决这个问题,但还没有成功。我什至不知道如何开始研究这个(尽管我已经尝试了一些谷歌搜索,但无济于事),所以我决定在这里问这个问题。
是否可以从 Through2 对象流返回多个乙烯基文件?
我的用例是这样的:我通过流接收一个 HTML 文件。我想隔离文件的两个不同部分(使用 jQuery),并在两个单独的 HTML 文件中返回它们。我可以用一个部分(和一个生成的 HTML 文件)来做到这一点,但我完全不知道我将如何生成两个不同的文件。
谁能在这里帮我一把?提前谢谢。
基本方法是这样的:
-
使用
clone()
函数根据需要从输入文件创建任意数量的输出文件。
根据 要执行的操作修改每个文件的
.contents
属性。 不要忘记这是一个缓冲区,而不是一个字符串。修改每个文件的
.path
属性,以便文件不会相互覆盖。这是一条绝对的路径,因此请使用类似path.parse()
和path.join()
之类的东西来使事情变得更容易。从
through2
转换函数中为已创建的每个文件调用this.push()
。
下面是一个快速示例,它将文件test.txt
拆分为两个test1.txt
和test2.txt
相同的大文件:
var gulp = require('gulp');
var through = require('through2').obj;
var path = require('path');
gulp.task('default', function () {
return gulp.src('test.txt')
.pipe(through(function(file, enc, cb) {
var c = file.contents.toString();
var f = path.parse(file.path);
var file1 = file.clone();
var file2 = file.clone();
file1.contents = new Buffer(c.substring(0, c.length / 2));
file2.contents = new Buffer(c.substring(c.length / 2));
file1.path = path.join(f.dir, f.name + '1' + f.ext);
file2.path = path.join(f.dir, f.name + '2' + f.ext);
this.push(file1);
this.push(file2);
cb();
}))
.pipe(gulp.dest('out'));
});