我在 for 循环中调用了 FileReader API 来遍历多个文件对象。我正在使用 FileReader 实质上显示图像的预览。
function() {
for (var i in Files) {
var fileReader = new FileReader();
fileReader.readAsBinaryString(Files[i]);
fileReader.onload = function() {
// do something on FileReader onload
}
fileReader.onprogress = function(data) {
if (data.lengthComputable) {
var progress = parseInt( ((data.loaded / data.total) * 100), 10 );
console.log(progress);
}
}
}
// do something on completion of FileReader process
// actions here run before completion of FileReader
}
由于 FileReader API 的异步性质,我遇到了两个问题。首先,onprogress
每个 FileReader 实例都会触发该事件。这给了我每个文件的进度。然而,我打算显示所有文件而不是单个文件的总进度。
其次,我想执行仅在 FileReader 的所有实例(每个文件一个)完成时才应执行的操作。目前,由于 FileReader 是异步运行的,因此操作会在 FileReader 完成其任务之前运行。我进行了很多搜索,但尚未找到解决这些问题的方法。任何帮助表示赞赏。