Usa promesas para gestionar tareas asincrónicas en JS

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

Algunos de nuestros reconocimientos:

Premios KeepCoding

En este artículo, exploraremos cómo usar promesas para gestionar tareas asincrónicas en JavaScript y cómo esta técnica puede mejorar la eficiencia de tu código asíncrono. Sabemos que, en el vertiginoso mundo del desarrollo web, la gestión de tareas asíncronas es esencial para garantizar que las aplicaciones funcionen sin problemas y de manera eficiente. La base de datos de una aplicación, las solicitudes de red o cualquier operación que pueda llevar tiempo deben manejarse de forma asíncrona para evitar bloquear la interfaz de usuario y proporcionar una experiencia de usuario fluida.

Promesas para gestionar tareas asincrónicas: ¿en qué consiste?

Las promesas son un concepto fundamental en JavaScript cuando se trata de operaciones asíncronas. Son objetos que representan el resultado de una operación asíncrona que puede estar en uno de los siguientes estados: pendiente, resuelta o rechazada. Las promesas permiten encadenar múltiples operaciones asíncronas de manera más legible y controlada.

Ahora bien, las promesas para gestionar tareas asincrónicas funcionan mediante un sistema de estados y callbacks que permiten realizar operaciones asíncronas de manera más legible y manejable.

La operación asíncrona de ejemplo

Para comprender mejor cómo funcionan las promesas para gestionar tareas asincrónicas, veamos un ejemplo de una operación asíncrona común: la lectura de datos de una base de datos.

function leerDatosDeBaseDeDatos() { 
return new Promise((resolve, reject) => { 
setTimeout(() => { 
const datos = "Estos son los datos de la base de datos."; 
if (datos) { 
resolve(datos); 
} else { 
reject("Error al leer datos de la base de datos."); 
} 
}, 2000); 
}); 
}

En este ejemplo, leerDatosDeBaseDeDatos devuelve una promesa que simula la lectura de datos de una base de datos después de un retraso de 2 segundos. Si la operación tiene éxito, se resuelve la promesa con los datos. De lo contrario, se rechaza con un mensaje de error.

Utilizando Async/Await con promesas

La sintaxis de promesas puede ser un poco complicada cuando se trabaja con múltiples operaciones asíncronas. Aquí es donde entran en juego las palabras clave async y await. Estas dos palabras clave hacen que el código asíncrono sea más legible y fácil de manejar.

async function obtenerDatosDeBaseDeDatos() { 
try { 
const datos = await leerDatosDeBaseDeDatos(); 
console.log(datos); 
} catch (error) { 
console.error(error); 
} 
}

Con async y await, podemos escribir código asíncrono de manera más similar a un código síncrono, lo que lo hace mucho más comprensible.

Manejando errores con el método catch

Cuando se utilizan promesas para gestionar tareas asincrónicas, es importante manejar los errores de manera adecuada. Esto se hace comúnmente utilizando el método catch en la cadena de promesas. El método catch permite capturar y manejar cualquier error que se genere durante la ejecución de la promesa.

function obtenerDatos() { 
return leerDatosDeBaseDeDatos() 
.then((datos) => { 
console.log(datos); 
}) 
.catch((error) => { 
console.error(error); 
}); 
}

Encadenando promesas

Una de las ventajas clave de las promesas es la capacidad de encadenar múltiples operaciones asíncronas de manera sencilla. Esto permite ejecutar tareas en secuencia, donde el resultado de una promesa se pasa como entrada a la siguiente.

function operacionCompleja() { 
return obtenerDatos() 
.then((datos) => procesarDatos(datos)) 
.then((resultado) => guardarResultado(resultado)) 
.catch((error) => { 
console.error(error); 
}); 
}

Resolviendo promesas para gestionar tareas asincrónicas

Las promesas se resuelven cuando se llama a la función resolve dentro de la promesa. Esto significa que la operación asíncrona se ha completado con éxito y devuelve una promesa resuelta con los datos necesarios.

function leerDatosDeBaseDeDatos() { 
return new Promise((resolve, reject) => { 
setTimeout(() => { 
const datos = "Estos son los datos de la base de datos."; 
if (datos) { 
resolve(datos); 
} else { 
reject("Error al leer datos de la base de datos."); 
} 
}, 2000); 
}); 
}

En resumen, el uso de promesas para gestionar tareas asincrónicas en JavaScript es esencial para desarrollar aplicaciones web eficientes y responsivas. Las promesas, combinadas con las palabras clave async y await, simplifican la escritura y el manejo de código asíncrono, lo que hace que sea más fácil de entender y mantener.

Sigue aprendiendo en KeepCoding

Si estás interesado en profundizar tus conocimientos en las promesas para gestionar tareas asincrónicas, en el desarrollo web y convertirte en un desarrollador Full Stack, considera unirte al Desarrollo Web Full Stack Bootcamp de KeepCoding. Este bootcamp te brindará las habilidades y conocimientos necesarios para enfrentarte a los desafíos del sector tecnológico en constante evolución. Al finalizar el bootcamp, estarás preparado para una carrera emocionante en la industria de la tecnología, que ofrece salarios competitivos y una estabilidad laboral que pocos otros sectores pueden igualar.

Recuerda que contamos con los mejores profesionales quienes te guiarán por tu proceso de aprendizaje con metodologías enfocadas en la práctica y casos reales. ¡No pierdas esta oportunidad de cambiar tu vida y unirte a una industria en auge!

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.