No es necesario usar useEffect para obtener datos en React
Dec 07 2022
Hola, en este blog intentaremos deshacernos de useEffect en el renderizado inicial con la ayuda de react-router. React router v6 salió con algunos ganchos nuevos y geniales que ayudarán a facilitar el proceso de carga de datos y envío de formularios.
Hola, en este blog intentaremos deshacernos del useEffectrenderizado inicial con la ayuda de react-router. React router v6 salió con algunos ganchos nuevos y geniales que ayudarán a facilitar el proceso de carga de datos y envío de formularios. Gracias al equipo de Remix .
Como lo mencionó el equipo de React: UseEffect es para synchronisationno para lifecycle methods.
En nuestra aplicación de reacción, generalmente llamamos a la API useEffectcomo ejemplo que se muestra a continuación. Pero en React 18, este useEffect se llama dos veces y algunos desarrolladores piensan que se trata de un error en React, ya que esto ocurre solo en el modo de desarrollo, créanme, esto no es un error.
import React, { useState, useEffect } from 'react';
const Homepage = () => {
const [data, setData] = useState(null);
useEffect(() => {
// Fetch the data from the API
fetch('https://example.com/api/data')
.then((response) => response.json())
.then((json) => setData(json));
}, []);
// Return a loading message while the data is being fetched
if (data === null) {
return <p>Loading...</p>;
}
// Render the data when it is available
return <pre>{JSON.stringify(data, null, 2)}</pre>;
};
export default Homepage;
import { createBrowserRouter, defer } from "react-router-dom";
const router = createBrowserRouter([
{
path: "/",
element: <Homepage/>,
loader: async ({ request, params }) => {
const data = fetch('https://example.com/api/data')
return defer({
results: data,
})
},
},
]);
import React from 'react';
import { useLoaderData } from "react-router-dom";
const Homepage = () => {
const data = useLoaderData()
// Render the data when it is available
return <pre>{JSON.stringify(data, null, 2)}</pre>;
};
export default Homepage;
import React from 'react';
import { useLoaderData, Await } from "react-router-dom";
const Homepage = () => {
const data = useLoaderData()
// Render the data when it is available
return <React.Suspense
fallback={<p>Loading data...</p>}
>
<Await
resolve={data.result}
errorElement={
<p>Error loading data</p>
}
>
{(result) => (
<pre>{JSON.stringify(results, null, 2)}</pre>
)}
</Await>
</React.Suspense>
};
export default Homepage;

![¿Qué es una lista vinculada, de todos modos? [Parte 1]](https://post.nghiatu.com/assets/images/m/max/724/1*Xokk6XOjWyIGCBujkJsCzQ.jpeg)



































