我想将 XHR 与 Promise 一起使用。我按照 HTML5 Rocks (1) 和 Mozilla 网站 (2) 上的建议创建了 XHR Promise。
它没有按预期工作。如果我有以下顺序来加载和处理文件:
sequence = xhrPromise('filename').
.then(parseFile)
.then(processFile)
.then(allSet);
如果我只运行 1 个序列,它会按预期工作。
如果我尝试使用 Promise.all() 运行 N 个序列来下载/处理 N 个文件,它会中断。
所有下载都以“并行”方式开始,然后一旦第一个 XHR 请求完成,它就会停止下载其他文件,运行该文件的完整序列,然后继续下载剩余文件。然后,一旦另一个文件完成,它会阻止下载,运行该文件的序列,然后继续下载等等。
这似乎是预期的行为,因为 XHR 进度事件被抛出主任务队列并且承诺正在使用微任务队列。
是否有意义?
如果我使用“获取”API 而不是 XHR,但无法监控下载进度,它似乎可以按预期工作,这对我来说是一个交易破坏者。
有没有解决这个问题的好方法?
(1) http://www.html5rocks.com/en/tutorials/es6/promises/
(2) https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise