0

我想将 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

4

1 回答 1

0

它停止下载其他文件

你是什​​么意思?IO 发生在主线程之外,即使您执行 javascript,下载也会继续。尽管如果您对结果进行一些繁重的处理,您可能希望查看webworkers以不阻塞主 UI 线程。

于 2015-06-06T17:59:24.063 回答