DEV Community

Promise.all()

Here's an interesting article on using Promise.all().

Understanding Promise.all() in JavaScript

Promise.all() is a powerful method in JavaScript that allows developers to handle multiple asynchronous operations concurrently. This method takes an iterable (usually an array) of promises and returns a single promise that resolves when all the input promises have resolved or rejects if any of the promises fail. This guide will explore the functionality of Promise.all(), its syntax, behavior, and practical examples.

Syntax

The syntax for Promise.all() is straightforward:

Promise.all(iterable);
Enter fullscreen mode Exit fullscreen mode
  • iterable: An array or other iterable object containing promises or values. Non-promise values are treated as resolved promises.

Return Value

The method returns a promise with the following behaviors:

  • If the iterable is empty, it resolves immediately with an empty array.
  • If all promises in the iterable are fulfilled, it resolves to an array of the fulfilled values, maintaining their order.
  • If any promise is rejected, it immediately rejects with the reason of the first rejected promise, ignoring all other promises' results.

Fulfillment and Rejection

  1. Fulfillment: When all promises resolve successfully, Promise.all() returns an array of results in the same order as the input promises.
  2. Rejection: If any promise is rejected, Promise.all() rejects immediately with the rejection reason of that promise.

Practical Examples

Example 1: Basic Usage

In this example, we create three promises that resolve after different timeouts:

const promise1 = new Promise((resolve) => setTimeout(() => resolve('One'), 1000));
const promise2 = new Promise((resolve) => setTimeout(() => resolve('Two'), 2000));
const promise3 = new Promise((resolve) => setTimeout(() => resolve('Three'), 3000));

Promise.all([promise1, promise2, promise3])
  .then(values => console.log(values)) // Output: ['One', 'Two', 'Three']
  .catch(error => console.error(error));
Enter fullscreen mode Exit fullscreen mode

Here, Promise.all() waits for all three promises to resolve and logs their results as an array.

Example 2: Handling Mixed Values

You can also mix resolved values and promises:

const p1 = Promise.resolve(42);
const p2 = Promise.resolve('Hello');
const p3 = new Promise((resolve) => setTimeout(() => resolve('World'), 1000));

Promise.all([p1, p2, p3])
  .then(values => console.log(values)) // Output: [42, 'Hello', 'World']
  .catch(error => console.error(error));
Enter fullscreen mode Exit fullscreen mode

In this case, p1 and p2 are resolved immediately while p3 resolves after one second.

Example 3: Rejection Handling

If one of the promises is rejected, Promise.all() will reject immediately:

const p1 = Promise.resolve(42);
const p2 = Promise.reject(new Error('Failed!'));
const p3 = new Promise((resolve) => setTimeout(() => resolve('This will not run'), 1000));

Promise.all([p1, p2, p3])
  .then(values => console.log(values))
  .catch(error => console.error(error.message)); // Output: 'Failed!'
Enter fullscreen mode Exit fullscreen mode

Here, because p2 is rejected, the entire operation fails and logs the error message.

Use Cases for Promise.all()

  • Fetching Multiple Resources: When you need to fetch data from multiple APIs simultaneously and wait for all responses before proceeding.
  • Parallel Processing: Executing multiple independent tasks at once where their results are needed together.
  • Batch Operations: Performing batch updates or calculations where each operation can be done independently.

Conclusion

Promise.all() is a fundamental tool for managing multiple asynchronous operations in JavaScript. It simplifies code by allowing developers to wait for several promises to resolve before proceeding with further logic. However, it’s crucial to handle rejections properly since any single failure among the promises will cause the entire operation to fail. Understanding how to effectively use Promise.all() can lead to cleaner and more efficient asynchronous code.

Citations:
[1] https://www.geeksforgeeks.org/javascript-promise-all-method/
[2] https://stackoverflow.com/questions/42210200/adding-a-promise-to-promise-all
[3] https://www.w3schools.com/jsref/jsref_promise_all.asp
[4] https://www.freecodecamp.org/news/promise-all-in-javascript-with-example-6c8c5aea3e32/
[5] https://www.simplilearn.com/promise-in-javascript-article
[6] https://www.reddit.com/r/node/comments/argxni/alternative_to_promiseall/
[7] https://dev.to/swarnaliroy94/methods-of-promise-all-any-finally-o2e
[8] https://www.geeksforgeeks.org/javascript-promise/
[9] https://dmitripavlutin.com/promise-all/
[10] https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all

Top comments (0)