我一直试图自己解决这个问题,但还没有成功。我什至不知道如何开始研究这个(虽然我已经尝试了一些谷歌搜索,但无济于事),所以我决定在这里问这个问题。
是否可以从 Through2 对象流中返回多个乙烯基文件?
我的用例是这样的:我通过流接收一个 HTML 文件。我想隔离文件的两个不同部分(使用 jQuery)并将它们返回到两个单独的 HTML 文件中。我可以用一个部分(和一个生成的 HTML 文件)来完成,但我完全不知道如何生成两个不同的文件。
任何人都可以在这里帮我一把吗?提前致谢。
基本方法是这样的:
clone()
使用该函数根据需要从输入文件创建尽可能多的输出文件。
修改.path
每个文件的属性,使您的文件不会相互覆盖。这是一条绝对路径,因此请使用类似的东西path.parse()
并path.join()
让事情变得更容易。
this.push()
从您创建的每个文件的through2
转换函数中调用。
这是一个将文件拆分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'));
});