react代码分割

React 代码分割(Code Splitting)主要是为了 优化首屏加载速度,避免一次性加载整个应用,把代码拆分成多个 bundle,按需加载。常见的方式有三种:


1. 使用 React.lazy + Suspense(推荐方式)

适合组件级别的代码分割。

javascript 复制代码
import React, { Suspense } from "react";

// 按需加载组件
const PerformanceReport = React.lazy(() => import("./pages/PerformanceReport"));

function App() {
  return (
    <div>
      <h1>云鉴性能平台</h1>
      <Suspense fallback={<div>Loading...</div>}>
        <PerformanceReport />
      </Suspense>
    </div>
  );
}

export default App;
  • React.lazy:实现组件的懒加载
  • Suspense:加载时的兜底 UI(比如 Loading 动画)

2. 路由级别代码分割(React Router)

如果你用 react-router-dom,可以结合 React.lazy 在路由层做代码分割。

javascript 复制代码
import React, { Suspense } from "react";
import { BrowserRouter as Router, Routes, Route } from "react-router-dom";

const PerformanceQuery = React.lazy(() => import("./pages/PerformanceQuery"));
const PerformanceReport = React.lazy(() => import("./pages/PerformanceReport"));

function AppRouter() {
  return (
    <Router>
      <Suspense fallback={<div>页面加载中...</div>}>
        <Routes>
          <Route path="/query" element={<PerformanceQuery />} />
          <Route path="/report" element={<PerformanceReport />} />
        </Routes>
      </Suspense>
    </Router>
  );
}

export default AppRouter;

👉 常见做法:

  • 首页加载最少的 bundle
  • 进入对应页面时再动态加载该页面的 JS

3. 动态 import(webpack 原生支持)

适合某些 工具类模块特定场景的函数,避免一开始全量加载。

javascript 复制代码
async function loadExcelExport() {
  const { exportToExcel } = await import("./utils/excelExport");
  exportToExcel();
}

4. 更高级的代码分割工具

  • Loadable Components:更灵活的懒加载方案,支持 SSR。
  • Webpack SplitChunksPlugin :拆分公共代码,比如 react, lodash
  • Vite/Rollup:天然支持动态 import,自动分割 bundle。

📌 建议实践:

  1. 路由层做大块分割(每个页面一个 bundle)
  2. 工具函数/图表库按需 import(避免首页加载太大)
  3. 配合 浏览器缓存,重复访问时会更快

相关推荐
还是大剑师兰特11 分钟前
Stats.js 插件详解及示例(完全攻略)
前端·大剑师·stats
前端小超超12 分钟前
Vue计算属性computed:可写与只读的区别
前端·javascript·vue.js
IT_陈寒1 小时前
SpringBoot实战:3个隐藏技巧让你的应用性能飙升50%
前端·人工智能·后端
weixin199701080161 小时前
唯品会商品详情页前端性能优化实战
前端·性能优化
爱学习的程序媛1 小时前
【Web前端】Pinia状态管理详解
前端·vue.js·typescript
爱学习的程序媛1 小时前
“数字孪生”详解与前端技术栈
前端·人工智能·计算机视觉·智慧城市·信息与通信
海石1 小时前
微信小程序开发02:原始人也能看懂的着色器与视频处理
前端·微信小程序·视频编码
程序员Sunday1 小时前
Claude Code 生态爆发:5个必知的新工具
前端·人工智能·后端
ChoSeitaku2 小时前
NO.2|proto3语法|消息类型|通讯录|文件读取|enum类型
java·服务器·前端
小J听不清2 小时前
CSS 边框(border)全解析:样式 / 宽度 / 颜色 / 方向取值
前端·javascript·css·html·css3