gpt4 book ai didi

javascript - 当任何 promise 都实现时,是否有可能脱离 await Promise.all (Chrome 80)

转载 作者:行者123 更新时间:2023-12-03 13:39:51 24 4
gpt4 key购买 nike

我需要向多台服务器发送请求,以查看哪个服务器将响应我的请求,如果其中任何一个响应,我将进一步与该服务器交互。最简单的方法是按顺序发送我的请求,像这样

async function probing(servers) {
for (const server of servers) {
const result = await fetch(server)
if (result.status == 200) {
return result
}
}
}
但我希望加快探测过程,所以我将代码更改为
async function probing(servers) {
results = await Promise.all(
servers.map(async server => {
return await fetch(server)
})
)
for (const result of results) {
if (result.status == 200) return result
}
}
但我仍然需要等待所有的 promise 完成。我真正需要的是,如果他们中的一个人已经解决了,然后我会从我的 probing() 中返回
那可能吗?
- - 更新 - -
感谢评论 promise.any 是解决方案(单线箭头函数可以进一步简化如下)
result = await Promise.any(
servers.map(server => fetch(server))
)
---- 更新 2 ----
我还以为 Promise.any 是要走的路,也是故事的结局。但不幸的是,事实并非如此! Promise.any仅适用于 Chrome 85+ 和 FF 79+,不像 Promise.all 可用于除 IE 之外的任何现代浏览器,请在此处查看 https://v8.dev/features/promise-combinators
我的客户需要我从 2020 年开始支持 Chrome 版本,即 Chrome 80+,
我试图填充 Promise.any 与通天塔,但我失败了。
我们使用 通天塔6 我没有用 babel6 填充 Promise.any。我尝试升级到 巴别塔 (带有 npx babel-upgrade --write 和一些曲折)现在使用 Promise.any() 的捆绑代码甚至不能用于 chrome 88。我问了另一个问题 How do I polyfill Promise.any() using babel 7?
所以现在我只需要恢复到 Promise.all。
---- 更新 3 ----
我终于做了 polyfill Promise.any()使用 Babel 7 工作,关键是使用 core-js@3使用正确的 babelrc 设置(我不确定我是否都正确),请引用我的问题并在那里回答。

最佳答案

在这种情况下 Promise.race()看起来很合理,但是 Promise.race() 的问题比赛中的任何拒绝 promise 都会使整个比赛崩溃。如果我们想要忽略个别拒绝并继续比赛,那么我们仍然有一个选择,在这种情况下,只有当所有 promise 都被拒绝时,我们才必须执行一个操作来处​​理错误。
所以如果我们发明 Promise.invert()并将它与 Promise.all() 一起使用,然后我们得到我们想要的。

var invert = pr => pr.then(v => Promise.reject(v), x => Promise.resolve(x));
让我们看看如何使用它;

var invert     = pr  => pr.then(v => Promise.reject(v), x => Promise.resolve(x)),
random = r => ~~(Math.random()*r),
rndPromise = msg => random(10) < 3 ? Promise.reject("Problem..!!!")
: new Promise((v,x) => setTimeout(v,random(1000),msg)),
promises = Array.from({length: 4}, (_,i) => rndPromise(`Promise # ${i}.. The winner.`));

Promise.all(promises.map(pr => invert(pr)))
.then(e => console.log(`Error ${e} happened..!!`))
.catch(v => console.log(`First successfully resolving promise is: ${v}`));

所以既然 promise 现在被反转了 catch是我们处理结果的地方,而 then是错误处理的地方。
我认为你可以在生产代码中安全地使用它,只要你为将来阅读的任何人都很好地注释了这个代码块。

关于javascript - 当任何 promise 都实现时,是否有可能脱离 await Promise.all (Chrome 80),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66044132/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com