react中懒加载实现原理

简介: react中懒加载实现原理

1. 前言

  1. 除了自己写懒加载和使用第三方懒加载之外,react也支持懒加载的
  2. ,react咋支持懒加载的? 看完写呗

2. React.lazy

  1. react中懒加载(Lazy Loading)是一种延迟加载组件或资源的技术,它可以提高应用程序的初始加载速度,只有在需要时才加载所需的组件或资源。React通过动态导入(Dynamic Import)和React的Suspense组件实现懒加载。
  2. React 16.6 版本中,新增了 React.lazy 函数,它能让你像渲染常规组件一样处理动态引入的组件

3.   动态导入

  1. 在组件中使用动态导入来引入需要懒加载的组件。
  2. 动态导入是ES6的一项功能,可以将模块作为函数调用并返回一个Promise对象。

const LazyComponent = React.lazy(() => import('./LazyComponent'));
  • 使用React.lazy()函数:

1.React.lazy()函数是React提供的用于实现懒加载的函数,它接受一个函数作为参数,该函数返回一个动态导入的Promise对象。

2.React.lazy()返回一个新的组件,该组件在需要时自动加载动态导入的组件


4. 使用Suspense组件

1.在应用程序的根组件懒加载组件父组件中,使用Suspense组件来包裹懒加载的组件,并设置fallback属性,指定在加载过程中显示的加载指示器或占位内容。

import React, { Suspense } from 'react';
const App = () => {
  return (
    <div>
      <h1>My App</h1>
      <Suspense fallback={<div>Loading...</div>}>
        <LazyComponent />
      </Suspense>
    </div>
  );
};
  1. LazyComponent是一个需要懒加载的组件,通过React.lazy()函数进行懒加载
  2. 然后在应用程序的根组件App中使用Suspense组件来包裹LazyComponent。
  3. 在加载过程中,Suspense组件会显示fallback属性指定的加载指示器或占位内容。
  • 当应用程序渲染时,懒加载的组件将在需要时动态加载,直到加载完成后才显示在页面上。
    这样可以减少初始加载时间,提高应用程序的性能和用户体验。

5. 懒加载只适用于默认导出的组件

1.如果需要导出多个组件,则需要使用命名导出,并通过解构赋值导入所需的组件。

// 懒加载多个组件
const { Component1, Component2 } = React.lazy(() => import('./LazyComponents'));


参考资料


初心

我所有的文章都只是基于入门,初步的了解;是自己的知识体系梳理,如有错误,道友们一起沟通交流;
如果能帮助到有缘人,非常的荣幸,一切为了部落的崛起;
共勉
相关文章
|
4天前
|
JSON 缓存 前端开发
【React】React原理面试题集锦
本文集合一些React的原理面试题,方便读者以后面试查漏补缺。作者给出自认为可以让面试官满意的简易答案,如果想要了解更深刻,可以点击链接查看对应的详细博文。在此对链接中的博文作者非常感谢🙏。
43 0
|
4天前
|
前端开发 JavaScript
React和Vue实现路由懒加载
React和Vue实现路由懒加载
37 2
|
4天前
|
存储 资源调度 前端开发
React原理 即 React路由基础
React原理 即 React路由基础
52 1
|
4天前
|
前端开发 JavaScript 算法
react diff 原理
react diff 原理
|
4天前
|
存储 人工智能 开发框架
【AI大模型应用开发】【AutoGPT系列】0. AutoGPT概念及原理介绍 - Agent开发框架及ReAct方法
【AI大模型应用开发】【AutoGPT系列】0. AutoGPT概念及原理介绍 - Agent开发框架及ReAct方法
30 0
|
4天前
|
前端开发 UED 开发者
react路由懒加载lazy直接使用组件标签引发的问题?
react路由懒加载lazy直接使用组件标签引发的问题?
168 0
|
4天前
|
前端开发 JavaScript 算法
React原理
【4月更文挑战第4天】本文介绍了React的核心概念,包括jsx、React.createElement和fiber。jsx是React的语法糖,被转换为React.createElement生成虚拟DOM (vDOM)以优化性能。vDOM是轻量的数据结构,用于描述DOM状态。React通过fiber结构改进渲染性能,将同步任务拆分成小任务,利用requestIdleCallback在浏览器空闲时执行,确保流畅的用户体验。fiber是增强的vDOM,包含额外的引用指针。文章还提及了diff算法和hooks在React中的作用。
11 0
|
4天前
|
前端开发 JavaScript
前端框架React原理
前端框架React原理
34 0
|
4天前
|
前端开发 JavaScript API
介绍一下React Router的工作原理。
介绍一下React Router的工作原理。
35 5
|
4天前
|
前端开发
《深入理解前端框架React Hooks的原理与实践》
本文将深入探讨前端框架React中Hooks的原理及其实际应用,帮助读者更好地理解React Hooks的工作机制,并通过示例代码展示如何利用Hooks来提升前端开发效率和代码质量。
41 0

热门文章

最新文章