当前位置: 首页 > news >正文

React中Suspense的分包实践

首先预备目录

//Footer.tsx
export const Footer = () => {return (<div>Footer</div>);
};
// Header.tsx
export const Header = () => {return (<div><h1>Header</h1></div>);
};
 // 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,包裹异步加载的组件打包后

//index.tsximport  { 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可以起到打包优化分包的作用

// App.tsx
import './App.css'
import {SuspenseDemo} from './components/3.SuspenseDemo/index.tsx'
function App() {return (<div> <SuspenseDemo/></div>)
}export default App

http://www.dtcms.com/a/545196.html

相关文章:

  • 垃圾收集器
  • CSharp UI更新及跨线程更新总结
  • 两个域名同一个网站做优化淘宝优惠网站怎么做
  • 深入仓颉UI:事件处理的声明式哲学与高阶实践
  • Actix Web 入门与实战
  • 外贸soho建站云南省建设厅网站二建
  • 20251029在AIO-3576Q38开发板的Android14下使用iperf3测试WIFI模块AP6256的网速【87.8 Mbits/sec】
  • 怎么用dede建设网站网站建设开放的端口
  • 基本select语句
  • linux命令-系统信息与监控-2
  • 【Ubuntu】安装amd驱动及ROCM后,系统起不来的问题分析及解决方案
  • 外国网站后台设计iis网页提示网站建设中
  • 镇江网站建设多少钱北京seo网站优化公司
  • 【第一章】金融数据的获取——金融量化学习入门笔记
  • MoonBit Pearls Vol.13:使用 MoonBit 开发一个 HTTP 文件服务器
  • 网站建设如何描述htm网站制作
  • SAP PP模块中流程制造
  • 网站攻击企业做营销型网站
  • SpringBoot项目集成easy-es框架
  • MySQL | 对数据库及数据库表格进行操作(实例)
  • 安装 ElasticSearch、Logstash、Kibana、Kafka 和 Filebeat
  • 从数据采集到智能诊断:阿尔泰科技实时高精度远距离管道状态监测全流程
  • MLGO微算法科技 LOP算法:实现多用户无线传感系统中边缘协同AI推理的智能优化路径
  • 签约快讯 | 当换科技携手体验家,重构二手3C全旅程体验
  • 2017网站开发新技术网站排名方法
  • flash打开网站源码网站开发亿玛酷出名5
  • ic电子网站建设网络营销策划推广方案
  • 视觉SLAM十四讲2nd—学习笔记(二)20250817
  • ADXL345 SPI加速度传感器Linux驱动开发笔记
  • 【自适应PF例程】基于Sage Husa的自适应粒子滤波与经典PF对比,MATLAB编写,可直接运行。三维状态量,非线性的状态与观测。附代码下载链接