不久, 订单被保留 。
按照您链接到的规范,
Promise.all(iterable)将一个
iterable即支持该[
Iterator接口的对象)作为参数,然后再调用
PerformPromiseAll( iterator, constructor,resultCapability)它,后者
iterable使用循环
IteratorStep(iterator)。
这意味着,如果
Promise.all()严格传递您传递给的迭代器,则一旦传递,它们仍将被订购。
通过
Promise.all()Resolve每个已解析的承诺都有一个内部
[[Index]]插槽的位置来实现解析,该插槽在原始输入中标记承诺的索引。
所有这一切意味着,只要严格按照输入顺序对输出进行严格排序(例如,数组)。
您可以在下面的小提琴(ES6)中看到这一点:
// Used to display resultsconst write = msg => { document.body.appendChild(document.createElement('div')).innerHTML = msg;};// Different speed async operationsconst 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 firstPromise.all([slow, instant, quick]).then(responses => { responses.map(response => write(response));});
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)