一尘不染

Promise.all:已解析值的顺序

javascript

查看MDN看起来像values传递给then()Promise的回调。all包含按promise顺序的值。例如:

var somePromises = [1, 2, 3, 4, 5].map(Promise.resolve);
return Promise.all(somePromises).then(function(results) {
  console.log(results) //  is [1, 2, 3, 4, 5] the guaranteed result?
});

谁能引用规范说明values应该遵循的顺序?

PS:运行这样的代码表明这似乎是对的,尽管这当然没有证据-可能是巧合。


阅读 721

收藏
2020-04-25

共1个答案

一尘不染

不久, 订单被保留

按照您链接到的规范,Promise.all(iterable)将一个iterable即支持该[Iterator接口的对象)作为参数,然后再调用PerformPromiseAll( iterator, constructor, resultCapability)它,后者iterable使用循环IteratorStep(iterator)
这意味着,如果Promise.all()严格传递您传递给的迭代器,则一旦传递,它们仍将被订购。

通过Promise.all()Resolve每个已解析的承诺都有一个内部[[Index]]插槽的位置来实现解析,该插槽在原始输入中标记承诺的索引。


所有这一切意味着,只要严格按照输入顺序对输出进行严格排序(例如,数组)。

您可以在下面的小提琴(ES6)中看到这一点:

// Used to display results

const write = msg => {

  document.body.appendChild(document.createElement('div')).innerHTML = msg;

};



// Different speed async operations

const slow = new Promise(resolve => {

  setTimeout(resolve, 200, 'slow');

});

const instant = 'instant';

const quick = new Promise(resolve => {

  setTimeout(resolve, 50, 'quick');

});



// The order is preserved regardless of what resolved first

Promise.all([slow, instant, quick]).then(responses => {

  responses.map(response => write(response));

});
2020-04-25