React中Suspense的分包实践

首先预备目录

TypeScript 复制代码
//Footer.tsx
export const Footer = () => {
  return (
    <div>
      Footer
    </div>
  );
};
TypeScript 复制代码
// Header.tsx
export const Header = () => {
  return (
    <div>
      <h1>Header</h1>
    </div>
  );
};
TypeScript 复制代码
 // index.tsx
import { Header } from "./Header";
import { Footer } from "./Footer";
 
//因为react的更新渲染DOM是自顶向下的,若遇到异步资源,则不知道如何做,就需要用Suspense来包裹
// 包裹之后它内部的机制就会发生变化了,它内部的异步操作可以暂停,暂停等到未来内部的内容得到了结果
// 返回成功后,Suspense才会渲染包裹的组件,否则会一直渲染loading,
 

//为了做一些异步读取的事情
// sspense的1.0版本
export const SuspenseDemo = () => {
  return <div> 
     <Header /> 
     <Footer /> 
     </div>;
};

执行pnpm build打包可以看到,项目中所有tsx文件只打包到一个js中

使用Suspense,包裹异步加载的组件打包后

TypeScript 复制代码
//index.tsx

import  { lazy,Suspense } from "react"; 
// 引入可以变为动态引入
const Header = lazy(()=>
  import("./Header").then((module) => ({
    default: module.Header
  }))

);
const Footer = lazy(()=>
  import("./Footer").then((module) => ({
    default: module.Footer
  }))

);
//因为react的自顶向下的,若遇到异步资源,则不知道如何做,就需要用Suspense来包裹
// 包裹之后它内部的机制就会发生变化了,它内部的异步操作可以暂停,暂停等到未来内部的内容得到了结果
// 返回成功后,Suspense才会渲染包裹的组件,否则会一直渲染loading,

 

//为了做一些异步读取的事情
// sspense的1.0版本
export const SuspenseDemo = () => {
  return <div>
    <Suspense fallback={<div>loading...</div>}>
     <Header /> 
     <Footer />
     </Suspense>
     </div>;
};

可以看到多出了Footer和Header的js文件,因此Suspense可以起到打包优化分包的作用

TypeScript 复制代码
// App.tsx
import './App.css'
import {SuspenseDemo} from './components/3.SuspenseDemo/index.tsx'
function App() {

  return (
    <div> 
      <SuspenseDemo/>
    </div>
  )
}

export default App
相关推荐
zopple22 分钟前
前端三剑客 vs Vue.js:核心区别解析
前端·javascript·vue.js
hsjcjh22 分钟前
窗口函数-详细讲解分析
java·服务器·前端
CDN36022 分钟前
【踩坑实录】前端开发必看:一次由CSS缓存引发的线上事故与SEO反思
前端·css·缓存
胡志辉的博客28 分钟前
本地明明好好的,怎么一上线就跨域了?把同源策略、前后端分工和 CORS 一次讲明白
前端·javascript·vue.js·reactjs·nextjs·跨域
|晴 天|31 分钟前
文章系列管理系统:拖拽排序与进度追踪
前端·vue.js·typescript
算是难了31 分钟前
TypeORM vs Prisma
数据库·typescript·node.js
GISer_Jing36 分钟前
AI Agent接口终局:MCP有弊端,CLI凭什么成为主流?
前端·人工智能
jiayong231 小时前
第 17 课:任务选择与批量操作
开发语言·前端·javascript·vue.js·学习
keyipatience1 小时前
3.Linux基本指令2
前端·html
Hhang1 小时前
从 ERP 系统出发,我是如何设计一套 LLM 多 Agent 系统的(二)
前端·人工智能·agent