From c33ecb63228026b3dfbb35186885daef42b1b6df Mon Sep 17 00:00:00 2001 From: sunilsoni Date: Tue, 17 Oct 2023 12:04:43 +0530 Subject: [PATCH] Lazy Loading --- docs/ui/react/components.md | 101 ++++++++++++++++++++++++++++++++++++ 1 file changed, 101 insertions(+) diff --git a/docs/ui/react/components.md b/docs/ui/react/components.md index 51ecea2..05a3ea1 100644 --- a/docs/ui/react/components.md +++ b/docs/ui/react/components.md @@ -1716,7 +1716,108 @@ function getDisplayName(WrappedComponent) { ## Lazy Loading + +### Set up lazy loading components + +**1. REACT.LAZY():** + +**React.lazy** is a function that lets you load components lazily through what is called code splitting without help from any external libraries. It makes possible for us to dynamically import components but they are rendered like regular components. This means that the bundle containing the component will only be loaded when the component is rendered. + +React.lazy() takes a function that returns a promise as it\'s argument, the function returns a promise by calling import() to load the content. The returned Promise resolves to a module with a default containing the React Component. + +```js +// Without Lazy +import MyComponent from './MyComponent'; + +// With Lazy +const MyComponent = React.lazy(() => import('./MyComponent')); +``` + +**2. SUSPENSE:** + +**React.Suspense** is a component that can be used to wrap lazy components. A React.Suspense takes a fallback prop that can be any react element, it renders this prop as a placeholder to deliver a smooth experience and also give user feedback while the lazy component is being loaded. + +```js +/** + * Suspense + */ +import React, { Suspense } from 'react'; + +const MyComponent = React.lazy(() => import('./MyComponent')); + +const App = () => { + return ( +
+ Loading ...
}> + + + + ); +} +``` + +**Example:** + +```js +/** + * React Lazy Loading Routes + */ +import React, { Suspense, lazy } from "react"; +import { Switch, BrowserRouter as Router, Route, Link } from "react-router-dom"; + +const Home = lazy(() => import("./Home")); +const ContactUs = lazy(() => import("./ContactUs")); +const HelpPage = lazy(() => import("./Help")); + +export default function App() { + return ( + +
    +
  • Home
  • +
  • ContactUs
  • +
  • HelpPage
  • +
+
+ Loading...}> + + + + + + +
+ ); +} +``` + + +--- + + + + +## ZZZZZ + + --- +## ZZZZZ + + +--- + + + +## ZZZZZ + + +--- + + + +## ZZZZZ + + +--- \ No newline at end of file