我需要将多个文件读入一个函数 A。我需要为此使用 FileAPI。但 FileReader 执行异步下载。我可以在不退出的情况下获取函数 A 末尾的所有文件的内容吗?
问问题
335 次
1 回答
1
只是为了非常清楚,FileReader
没有下载任何东西。它异步将文件内容(在磁盘上显示)读取到内存中。
要做你想做的事,只需跟踪读取的文件并在它们全部完成后调用回调:
document.querySelector('[type="file"]').change = function(e) {
handleFiles(toArray(e.target.files), function(results) {
// results is an Array containing the FileReader results.
alert('Done!');
});
function toArray(list) {
return Array.prototype.slice.call(list || [], 0);
}
function handleFiles(files, callback) {
var results = [];
files.forEach(function(file, i) {
var reader = new FileReader();
// Closure to capture the file information.
reader.onload = function(e) {
results.push(e.target.result);
if (results.length == files.length) {
callback(results);
}
};
reader.readAsDataURL(file);
});
}
试试看:http: //jsbin.com/epatel/3/edit#html,live
于 2011-12-26T19:54:43.843 回答