¿Cómo usar la herramienta Promise.all en JavaScript?

| Última modificación: 15 de marzo de 2024 | Tiempo de Lectura: 3 minutos

Algunos de nuestros reconocimientos:

Premios KeepCoding

En el mundo del desarrollo web, JavaScript es un lenguaje esencial que se utiliza para crear interactividad y dinamismo en las aplicaciones. Una de las características más poderosas de JavaScript es la capacidad de trabajar con promesas. Las promesas son objetos que representan un valor que puede estar disponible ahora, en el futuro o nunca. Entre las diversas funciones para trabajar con promesas, Promise.all en JavaScript es una herramienta especialmente útil.

¿Qué es Promise.all en JavaScript?

Promise.all en JavaScript es un método que se utiliza para manejar múltiples promesas de manera eficiente. Esta función toma un iterable de promesas como entrada y devuelve una nueva promesa que se resuelve solo cuando todas las promesas en el iterable se han resuelto o, si alguna de ellas se rechaza, se rechaza con el motivo de la primera promesa rechazada.

En otras palabras, Promise.all es una excelente manera de trabajar con un conjunto de promesas y esperar hasta que todas se completen antes de realizar una acción.

La sintaxis básica de Promise.all en JavaScript es la siguiente:

Promise.all(iterable);

Donde iterable es un iterable (por ejemplo, un array) que contiene promesas.

Usando Promise.all en JavaScript para esperar todas las promesas

Imagina que estás desarrollando una aplicación web que necesita cargar múltiples recursos, como imágenes, datos de API y archivos. En lugar de cargar estos recursos uno por uno, puedes utilizar Promise.all en JavaScript para cargarlos en paralelo y esperar hasta que todos estén disponibles antes de continuar.

const promises = [ 
fetch('https://api.example.com/data'), 
loadImage('image1.jpg'), 
loadImage('image2.jpg') 
]; 
Promise.all(promises) 
.then(results => { 
// Todas las promesas se han resuelto con éxito 
const apiData = results[0]; 
const image1 = results[1]; 
const image2 = results[2]; 
// Haz algo con los datos y las imágenes 
}) 
.catch(error => { 
// Al menos una promesa fue rechazada 
console.error(error); 
});

En este ejemplo, estamos utilizando Promise.all para esperar tanto la respuesta de la API como la carga de dos imágenes antes de continuar con el procesamiento de los datos.

Promise.all vs. Promise.allSettled

Es importante destacar que existe otra función llamada Promise.allSettled, que es similar a Promise.all, pero, en lugar de rechazar la promesa resultante si alguna de las promesas se rechaza, espera a que todas las promesas se resuelvan o se rechacen y luego devuelve un array de objetos que describen el estado de cada promesa. Esto puede ser útil si deseas conocer el resultado de todas las promesas, incluso si algunas de ellas se rechazan.

Manejando promesas individuales

Dentro de la función de resolución de Promise.all en JavaScript, puedes trabajar con las promesas individuales utilizando los valores del array results. Esto te permite acceder a los resultados de cada promesa y tomar decisiones basadas en ellos.

Promise.all(promises) 
.then(results => { 
results.forEach(result => { 
if (result instanceof Error) { 
// La promesa fue rechazada 
console.error(result);
 } else { 
// La promesa se resolvió con éxito 
console.log(result); 
} 
}); 
});

En resumen, Promise.all en JavaScript es una herramienta poderosa para manejar múltiples promesas de manera eficiente. Permite que tu código espere hasta que todas las promesas se resuelvan antes de continuar, lo que es especialmente útil en situaciones donde necesitas cargar múltiples recursos o realizar múltiples solicitudes de manera simultánea.

Únete al desarrollo web con KeepCoding

El mundo de la tecnología está en constante crecimiento y evolución y el sector IT ofrece una alta demanda de profesionales capacitados. Al unirte al Desarrollo Web Full Stack Bootcamp de KeepCoding, tendrás la oportunidad de adquirir las habilidades y el conocimiento necesarios para ingresar a esta industria en rápido crecimiento.

Al finalizar el bootcamp, te convertirás en un desarrollador web altamente cualificado, capaz de crear aplicaciones web sofisticadas y trabajar en una variedad de proyectos emocionantes. Además, el sector tecnológico ofrece salarios competitivos y una estabilidad laboral que pocos otros sectores pueden igualar.

No pierdas la oportunidad de cambiar tu vida y unirte a una comunidad de apasionados del desarrollo web en KeepCoding. ¡Inicia tu viaje hacia una carrera exitosa en tecnología y descubre las infinitas posibilidades que te esperan!

Alberto Casero

Alberto Casero es CTO en Watium, Fundador de Kas Factory & Coordinador del Bootcamp en Desarrollo Web.

Posts más leídos

¡CONVOCATORIA ABIERTA!

Desarrollo web

Full Stack Bootcamp

Conviértete en Full Stack Deeveloper en solo 10 meses. Accede a un sector con el 98,49% de empleabilidad con sueldos de hasta 80K.