• 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

94
Vistas
matriz de dependencia useEffect

Estoy usando customHook para obtener datos de una API.

 const useFetch = () => { const dispatch = useDispatch(); return async (callback, ...props) => { try { return await callback(...props); } catch (error) { const { msg } = error.response?.data || "Something went wrong"; dispatch(showModal(msg)); setTimeout(() => dispatch(hideModal()), 3000); } }; };

y usarlo dentro de useEffect

 const customFetch = useFetch(); useEffect(() => { (async () => { const data = await customFetch(fetchUsers, token); if (data) setUsers(data.user); })(); }, [token]);

Pero eslint se queja de la falta de dependencia de customFetch. Si lo agrego, terminará en un bucle infinito. ¿Cómo puedo arreglar esto?

about 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

Entonces solo necesita useCallback aquí para hacer que la devolución de llamada regrese estable:

 const useFetch = () => { const dispatch = useDispatch(); const fetcher = useCallback(async (callback, ...props) => { try { return await callback(...props); } catch (error) { const { msg } = error.response?.data || "Something went wrong"; dispatch(showModal(msg)); setTimeout(() => dispatch(hideModal()), 3000); } }, [dispatch]); return fetcher; };

useMemo y useCallback son específicamente útiles en casos como ese, cuando necesita que algo sea referencialmente igual, mientras que crear/devolver literalmente proporcionaría una nueva instancia en cada ejecución (función, matriz, objeto)

about 3 years ago · Juan Pablo Isaza Denunciar
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