Promise.all:已解析值的顺序

Promise.all:已解析值的顺序,第1张

Promise.all:已解析值的顺序

不久, 订单被保留

按照您链接到的规范,

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));});


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5509196.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-13
下一篇 2022-12-13

发表评论

登录后才能评论

评论列表(0条)

保存