Manejo de peticiones asíncronas con useEffect en React

| Ú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, el manejo de peticiones asíncronas es una habilidad esencial. En este artículo, exploraremos cómo manejar peticiones asíncronas con useEffect. Esto es especialmente importante en un contexto donde la velocidad y la eficiencia son clave.

Conceptos básicos de React hooks

Para comprender cómo manejar peticiones asíncronas con useEffect en React, es importante tener una comprensión sólida de los React hooks. Los hooks son funciones que te permiten enganchar el estado y otras características de React en componentes funcionales. Uno de los hooks más utilizados para el manejo de peticiones asíncronas es useState, que permite gestionar el estado local en un componente. A través de useState, puedes almacenar y actualizar la información que proviene de una petición asíncrona.

Nuestra primera petición fetch

Antes de profundizar en las peticiones asíncronas con useEffect, consideremos cómo realizar una petición fetch básica en React. La función fetch de JavaScript permite realizar solicitudes HTTP y se usa mucho para obtener datos de una API. Aquí hay un ejemplo de cómo se vería una solicitud Fetch en un componente de React:

import React, { useState, useEffect } from 'react'; 
function App() { 
const [data, setData] = useState([]); 
useEffect(() => { 
fetch('https://api.example.com/data') 
.then(response => response.json()) 
.then(data => setData(data)) 
.catch(error => console.error('Error:', error)); 
}, []); 
return ( 
<div> 
{/* Renderizar los datos obtenidos de la API */}
 </div>
 );
 } 
export default App;

En este ejemplo, useState se utiliza para mantener los datos de la API y useEffect se utiliza para realizar la solicitud Fetch cuando el componente se monta. El arreglo vacío [] como segundo argumento de useEffect garantiza que la solicitud se realice solo una vez, al igual que componentDidMount en componentes de clase.

Peticiones asíncronas con useEffect en React

Si bien el ejemplo anterior es útil, la mayoría de las peticiones asíncronas con useEffect requieren un enfoque más dinámico. Es posible que desees realizar una solicitud cada vez que un estado cambie o que necesites manejar solicitudes en cascada. Aquí es donde useEffect se vuelve invaluable.

import React, { useState, useEffect } from 'react'; 
function App() { 
const [data, setData] = useState([]); 
const [isLoading, setIsLoading] = useState(true); 
useEffect(() => { 
setIsLoading(true); 
fetch('https://api.example.com/data') 
.then(response => response.json()) 
.then(data => { 
setData(data); setIsLoading(false); 
}) 
.catch(error => console.error('Error:', error)); 
}, []); // Ejecutar solo una vez al montar el componente 
return (
 <div> 
{isLoading ? (
 <p>Cargando...</p> 
) : ( 
<div> 
{/* Renderizar los datos obtenidos de la API */} 
</div> 
)} 
</div> 
); 
} 
export default App;

En este ejemplo, se agrega un estado isLoading para controlar si los datos se están cargando o no. useEffect ahora actualiza tanto data como isLoading en función del resultado de la solicitud fetch. Esto proporciona una experiencia de usuario más fluida, ya que muestra un mensaje de carga mientras se obtienen los datos.

Siguiente forma de utilizar useEffect

La forma anterior de realizar peticiones asíncronas con useEffect es efectiva, pero en algunos casos, es posible que necesites ejecutar el efecto cada vez que un valor en particular cambie. Para lograrlo, simplemente incluye la variable o variables relevantes en el arreglo de dependencias del efecto.

import React, { useState, useEffect } from 'react'; 
function App() { 
const [data, setData] = useState([]); 
const [userId, setUserId] = useState(1); 
useEffect(() => { 
fetch(`https://api.example.com/user/${userId}`) 
.then(response => response.json()) 
.then(data => setData(data)) 
.catch(error => console.error('Error:', error)); 
}, [userId]); // Ejecutar cuando userId cambia 
return ( 
<div> 
{/* Renderizar los datos del usuario */} 
</div> 
); 
} 
export default App;

En este ejemplo, el efecto se ejecutará cada vez que userId cambie, lo que significa que obtendrá los datos del usuario correspondiente. Esto es especialmente útil cuando tienes componentes que dependen de datos específicos.

Beneficios de utilizar useEffect para data fetching

Manejar peticiones asíncronas con useEffect en React ofrece varios beneficios:

  • Reactividad y eficiencia: useEffect garantiza que los componentes de React se actualicen de manera eficiente cuando los datos cambian. Esto es fundamental para crear aplicaciones web receptivas y dinámicas.
  • Control de carga: Puedes controlar el estado de carga y mostrar mensajes o indicadores de carga mientras se obtienen los datos, mejorando la experiencia del usuario.
  • Flexibilidad: Puedes personalizar cuándo se ejecutan las solicitudes según tus necesidades específicas. Esto te brinda un alto grado de flexibilidad y control sobre el comportamiento de tu aplicación.

En resumen, el manejo de peticiones asíncronas con useEffect en React es una habilidad esencial para cualquier desarrollador web moderno. Los hooks de React, como useState y useEffect,simplifican el proceso y brindan un alto grado de control sobre la gestión de datos en tus aplicaciones.

Continúa tu aprendizaje en KeepCoding

¡No pierdas la oportunidad de cambiar tu vida! Al unirte a nuestro Desarrollo Web Full Stack Bootcamp, te embarcarás en un viaje que te llevará a dominar las tecnologías más solicitadas por la industria IT. Con una alta demanda de profesionales y salarios competitivos, el sector tecnológico ofrece una estabilidad laboral que pocos sectores son capaces de igualar. ¡No esperes más para cambiar tu vida y solicita información ahora!

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.