• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

223
Vistas
Datos no establecidos después de obtener en useEffect

Intento obtener datos de un servidor usando useEffect hook en react 18.0.0. Después de obtener los datos, quiero establecer el estado con el gancho useStat e. Intenté obtener los datos con la sintaxis .then() y la sintaxis async/await , pero intentar registrar el estado da undefined .

Variante 1) .then() -Sintaxis:

 const fetchData = () => { fetch("http://localhost:8080/user", { method: "GET", credentials: "include", headers: { "Content-Type": "application/json", }, }) .then(response => response.json()) .then(data => { console.log(data); setUser(data); console.log(user); }); }

Variante 2) async/await-Syntax:

 const asyncFetchData = async () => { const response = await fetch("http://localhost:8080/user", { method: "GET", credentials: "include", headers: { "Content-Type": "application/json", }, }); const data = await response.json(); console.log(data); setUser(() => data); console.log(user); }

Gancho de efecto y renderizado:

 useEffect(() => { asyncFetchData(); fetchData(); }, []); return ( <> <span>{'' + user?.username}</span> </> )

Comportamiento esperado:

El objeto de usuario debe registrarse 4 veces en la consola y el nombre de usuario debe mostrarse en la pantalla.

Problemas:

El objeto de usuario se registra dos veces cuando se llama a console.log(data) pero no cuando se llama a console.log(user) . Además, el nombre de usuario no se representa en la pantalla.

Probé varias respuestas en StackOverflow, por ejemplo, esta , pero ninguna funcionó.

¿Cómo resuelvo este error?

over 3 years ago · Juan Pablo Isaza
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda