【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;

路由懒加载的优点:

  • 懒加载减少初始加载时间和提⾼加载速度,通过拆分代码到更⼩的块并按需加载。
  • 它减少初始包⼤⼩,提⾼⽤户体验和减少资源加载。
相关推荐
be or not to be4 分钟前
CSS 背景(background)系列属性
前端·css·css3
前端snow9 分钟前
在手机端做个滚动效果
前端
webkubor20 分钟前
🧠 2025:AI 写代码越来越强,但我的项目返工却更多了
前端·机器学习·ai编程
Sun_小杰杰哇24 分钟前
Dayjs常用操作使用
开发语言·前端·javascript·typescript·vue·reactjs·anti-design-vue
戴维南26 分钟前
TypeScript 在项目中的实际解决的问题
前端
晴殇i28 分钟前
package.json 中的 dependencies 与 devDependencies:深度解析
前端·设计模式·前端框架
basestone29 分钟前
🚀 从重复 CRUD 到工程化封装:我是如何设计 useTableList 统一列表逻辑的
javascript·react.js·ant design
pas13631 分钟前
25-mini-vue fragment & Text
前端·javascript·vue.js
何贤35 分钟前
2025 年终回顾:25 岁,从“混吃等死”到别人眼中的“技术专家”
前端·程序员·年终总结
软件开发技术深度爱好者37 分钟前
JavaScript的p5.js库使用介绍
javascript·html