【React】路由懒加载

使⽤ React Router 进⾏⻚⾯路由时,将⻚⾯组件按需加载,⽽不是⼀次性加载所有⻚⾯组件。

路由懒加载的原理是基于 ES6 的动态 import 特性,通过在 Webpack 打包时使⽤ React.lazy() 和 Suspense 进⾏懒加载,当路由被匹配时才会加载对应的组件。

jsx 复制代码
import React, { lazy, Suspense } from 'react';
import { Route, Switch } from 'react-router-dom';
const Home = lazy(() => import('./components/Home'));
const About = lazy(() => import('./components/About'));
const Contact = lazy(() => import('./components/Contact'));
function App() {
	return (
	  <div>
	    <Suspense fallback={<div>Loading...</div>}>
	      <Switch>
	        <Route exact path="/" component={Home} />
	        <Route path="/about" component={About} />
	        <Route path="/contact" component={Contact} />
	      </Switch>
	    </Suspense>
	  </div>
	);
}
export default App;

路由懒加载的优点:

  • 懒加载减少初始加载时间和提⾼加载速度,通过拆分代码到更⼩的块并按需加载。
  • 它减少初始包⼤⼩,提⾼⽤户体验和减少资源加载。
相关推荐
周周爱喝粥呀1 小时前
【基础】Three.js 实现 3D 字体加载与 Matcap 金属质感效果(附案例代码)
前端·javascript·vue.js·3d
克喵的水银蛇1 小时前
Flutter 通用输入框封装实战:带校验 / 清除 / 密码切换的 InputWidget
前端·javascript·flutter
2501_915909061 小时前
Fiddler抓包与接口调试实战,HTTPHTTPS配置、代理设置与移动端抓包详解
前端·测试工具·ios·小程序·fiddler·uni-app·webview
我命由我123452 小时前
微信小程序开发 - 为 tap 事件的处理函数传递数据
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
百万蹄蹄向前冲5 小时前
Trae Genimi3跟着官网学实时通信 Socket.io框架
前端·后端·websocket
狂炫冰美式6 小时前
TRAE SOLO 驱动:重构AI模拟面试产品的复盘
前端·后端·面试
1024肥宅8 小时前
JavaScript 拷贝全解析:从浅拷贝到深拷贝的完整指南
前端·javascript·ecmascript 6
欧阳天风8 小时前
js实现鼠标横向滚动
开发语言·前端·javascript
局i9 小时前
Vue 指令详解:v-for、v-if、v-show 与 {{}} 的妙用
前端·javascript·vue.js
码界奇点9 小时前
Java Web学习 第15篇jQuery从入门到精通的万字深度解析
java·前端·学习·jquery