我正在尝试使用 Gulp
来实现这一点.
I'm trying to achieve this with Gulp
.
.json
文件,包括子目录.我迷失的地方是如何通过管道读取/写入 JSON 到 src
.
The point where I'm lost is how to pipe reading/writing JSON to src
.
我现在有以下骨架.
gulp.task("migratefiles", function () {
return gulp.src("files/**/*.json")
.pipe(/* WHAT HERE? */)
.pipe(gulp.dest("processed"));
});
有很多方法可以做到这一点:
There's a number of way you can do this:
(1) 使用 gulp-json-transform代码> 插件:
var jsonTransform = require('gulp-json-transform');
gulp.task("migratefiles", function () {
return gulp.src("files/**/*.json")
.pipe(jsonTransform(function(json, file) {
var transformedJson = {
"newRootLevel": json
};
return transformedJson;
}))
.pipe(gulp.dest("processed"));
});
优点:
Promise
)文件
缺点:
(2) 使用 gulp-json-editor代码> 插件:
var jeditor = require('gulp-json-editor');
gulp.task("migratefiles", function () {
return gulp.src("files/**/*.json")
.pipe(jeditor(function(json) {
var transformedJson = {
"newRootLevel": json
};
return transformedJson;
}))
.pipe(gulp.dest("processed"));
});
优点:
js-beautify
选项缺点:
(3) 手动操作(直接访问 vinyl
使用 map-stream
的文件对象):强>
var map = require('map-stream');
gulp.task("migratefiles", function () {
return gulp.src("files/**/*.json")
.pipe(map(function(file, done) {
var json = JSON.parse(file.contents.toString());
var transformedJson = {
"newRootLevel": json
};
file.contents = new Buffer(JSON.stringify(transformedJson));
done(null, file);
}))
.pipe(gulp.dest("processed"));
});
优点:
done
回调)缺点:
这篇关于读取一堆 JSON 文件,转换它们并保存它们的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!