查看MDN看起来像values传递给then()Promise的回调。all包含按promise顺序的值。例如:
values
then()
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:运行这样的代码表明这似乎是对的,尽管这当然没有证据-可能是巧合。
不久, 订单被保留 。
按照您链接到的规范,Promise.all(iterable)将一个iterable即支持该[Iterator接口的对象)作为参数,然后再调用PerformPromiseAll( iterator, constructor, resultCapability)它,后者iterable使用循环IteratorStep(iterator)。 这意味着,如果Promise.all()严格传递您传递给的迭代器,则一旦传递,它们仍将被订购。
Promise.all(iterable)
iterable
Iterator
PerformPromiseAll( iterator, constructor, resultCapability)
IteratorStep(iterator)
Promise.all()
通过Promise.all()Resolve每个已解析的承诺都有一个内部[[Index]]插槽的位置来实现解析,该插槽在原始输入中标记承诺的索引。
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)); });