Suspense
Suspense permet a un component pausar el renderitzat mentre espera que finalitzi un procés asíncron.
Introducció
Suspense is a built-in feature that simplifies managing asynchronous operations managing what is displayed while your components wait for asynchronous tasks to complete.
</Suspense>When React encounters the Suspense component, it checks if any child components are waiting for a promise to resolve.
If so, React “suspends” the rendering of those components and displays the fallback UI until the promise is resolved.
The fallback UI can be a paragraph, a component, or anything you prefer.
Data fetching
One of the primary use cases of Suspense is managing data fetching in your applications.
Using Suspense, you can display a loading state while fetching data from an API, providing a smoother user experience.
For example, the code below shows how the DataView fetches data and displays a loading message until the data is available.
;
;
return if !data throw promise;
}
return data;
}
};
};
;
<Suspense fallback=>
<DataComponent />
</Suspense>
);
;
return
div
h1Data: </h1>
</div>
);
};The fetchData function initiates a fetch request and returns an object with a read method. If the data isn’t ready, the read method throws a promise, which tells Suspense to display the fallback UI (“Loading data…”).
Once available, read returns the data, and DataComponent renders it.
Dades
Quan un component necessita mostrar unes dades que ha de proporiconar un servidor, el component no ha de parar el rederitzar de la página, sinó que ha de mostrar alguna cosa fins que obtingui les dades i pugui mostrar el contingut corresponent.
En aquests casos utilitza el component Suspense:
</Suspense>En el moment de renderitzar la pàgina, si el component <Data/> no està llest, React mostrarà el component <DataFallback/> en el seu lloc.
Aplicació
lazy()
React té un mecanisme d’importació dinàmica anomenat lazy() que et permet carregar un component només quan sigui necessari.
D’aquesta manera l’aplicació es pot dividir en scripts diferents, i l’script inicial és molt més petit i ràpid de carregar.
La funció lazy() accepta una funció que importa el component;
Estás leyendo una vista previa.
Inicia sesión para leer el artículo completo. Cualquier cuenta abre 4 artículos gratuitos al mes; el alumnado y el profesorado leen las páginas de su curso sin límite.
Iniciar sesión