Promise.allSettled():一行代码干掉 Promise.all,JavaScript 异步编程的终极简化!
				
									
					
					
						|  | 
							admin 2025年10月28日 23:35
								本文热度 329 | 
					
				 
				处理异步操作已经成为了 JavaScript 日常编码的核心部分。随着应用复杂度的增加,我们经常需要并发执行多个异步任务并合理处理它们的结果。长期以来,Promise.all() 一直是我们处理并发 Promise 的首选方法,但它存在一个致命缺陷:一旦任何一个 Promise 被拒绝(rejected),整个操作就会失败。
Promise.all 的局限性
让我们先回顾一下 Promise.all() 的工作方式及其局限性:
const promises = [
 fetch('/api/users'),
 fetch('/api/products'),
 fetch('/api/orders')
];
Promise.all(promises)
  .then(results => {
    // 处理所有成功结果
    const [users, products, orders] = results;
    // 进一步处理数据
  })
  .catch(error => {
    // 如果任何一个 Promise 失败,就会执行这里
    console.error('至少有一个请求失败:', error);
    // 但我们不知道哪些请求成功了,哪些失败了
  });
这种方法的主要问题在于:
- 任何一个 Promise 失败都会导致整个操作失败
- 你无法知道哪些操作成功,哪些失败
- 你无法获取成功操作的结果
在实际应用中,我们通常希望即使某些操作失败,也能继续处理成功的结果。例如,在加载仪表板组件时,即使某个组件的数据获取失败,我们也希望显示其他组件。
Promise.allSettled() 解决了上述所有问题。它会等待所有 Promise 完成(无论成功或失败),并返回一个包含每个 Promise 结果的数组:
const promises = [
 fetch('/api/users').then(r => r.json()),
 fetch('/api/products').then(r => r.json()),
 fetch('/api/orders').then(r => r.json())
];
Promise.allSettled(promises)
  .then(results => {
    results.forEach((result, index) => {
      if (result.status === 'fulfilled') {
        console.log(`Promise ${index} 成功:`, result.value);
      } else {
        console.log(`Promise ${index} 失败:`, result.reason);
      }
    });
    
    // 你可以处理所有成功的结果,同时了解哪些失败了
    const successfulData = results
      .filter(result => result.status === 'fulfilled')
      .map(result => result.value);
      
    // 处理成功获取的数据
    processData(successfulData);
  });
Promise.allSettled 返回值结构
Promise.allSettled() 的返回值是一个数组,每个元素对应一个 Promise 的结果,具有以下结构:
- 对于成功的 Promise:{ status: 'fulfilled', value: 结果值 }
- 对于失败的 Promise:{ status: 'rejected', reason: 错误原因 }
这种统一的结构使得处理结果变得简单明了。尤其在需要并发执行多个独立异步操作,并且希望无论个别操作成功与否都能获取完整结果的场景中,Promise.allSettled() 无疑是最佳选择。它使我们能够构建更具弹性的应用程序,优雅地处理现实世界中不可避免的错误和异常情况。
阅读原文:原文链接
该文章在 2025/10/29 18:43:27 编辑过