考虑以下场景:您有一个 URL 数组,并希望获取一个包含以下数组的对象:这些 URL 处的文件中的相应文本。 Promise.all 函数提供了一种处理此任务的便捷方法。
最初,您尝试使用 Promise.all 来检索每个 URL 的承诺。但是,随后对 results.forEach 的调用可能会导致混乱。此函数会触发每个元素的回调,从而产生一个未定义值的数组。
正确的方法是使用 Promise.all 两次。第一个实例从 URL 中获取响应,而第二个实例将响应转换为文本并返回这些文本的数组。
Promise.all(urls.map(u=>fetch(u))).then(responses => Promise.all(responses.map(res => res.text())) ).then(texts => { … })
或者,您可以通过直接从响应中获取文本来简化代码:
Promise.all(urls.map(url => fetch(url).then(resp => resp.text()) )).then(texts => { … })
使用 async/await 语法,代码变得更加简洁:
const texts = await Promise.all(urls.map(async url => { const resp = await fetch(url); return resp.text(); }));
通过使用这种方法,你可以有效地获取 URL 数组并获得一个对象相应的文本值。
以上是如何使用 Promise.all 高效地从 URL 数组中检索文本?的详细内容。更多信息请关注PHP中文网其他相关文章!