我有一个数组,它保存了几个文件的URL。例如:
var files = ['1.html', '2.html', '3.html'];
我需要异步读取它们并将它们保存在名为cache(cache = {})的对象中。 为此,我使用了代码:
for(var i = 0; i < files.length; i++){
require('fs').readFile(files[i], 'utf8', function (error,data) {
cache[files[i]]=data;
});
}
最后我得到了结果:
cache = { undefined : 'File 3 content' }
我确实理解“循环结束后”“readFile”会起作用并且它会失去它的范围。有没有办法解决这个或另一种方法从数组中读取文件并缓存它们?
答案 0 :(得分:16)
执行回调readFile
时,for循环已经完成。因此i
将files.length
而files[i]
将为undefined
。要缓解这种情况,您需要将变量包装在闭包中。最简单的方法是创建一个执行readFile
调用的函数,并在循环中调用它:
function read(file) {
require('fs').readFile(file, 'utf8', function (error,data) {
cache[file]=data;
});
}
for(var i = 0; i < files.length; i++){
read(files[i]);
}
为了更好的执行控制,您可能需要查看async:
function readAsync(file, callback) {
fs.readFile(file, 'utf8', callback);
}
async.map(files, readAsync, function(err, results) {
// results = ['file 1 content', 'file 2 content', ...]
});
编辑:为异步示例使用辅助函数。
答案 1 :(得分:0)
现有的答案对我不起作用。我找到了一个完成这项工作的NPM包:https://www.npmjs.com/package/read-multiple-files。在命令行npm install read-multiple-files
之后,这是我使用的代码:
var files = ['1.html', '2.html', '3.html'];
console.log("\n");
readMultipleFiles(files, 'utf8', function(err, inputFiles) {
if(err) {
console.log("Read Error: " + err);
}
fileOne = inputFiles[0];
fileTwo = inputFiles[1];
...
console.log(fileOne);
console.log(fileTwo);
});