React

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > React > react代码分割

react代码分割的三种实现方法

作者:光影少年

React代码分割主要是为了优化首屏加载速度,避免一次性加载整个应用,把代码拆分成多个bundle,按需加载,下面就一起来了解一下,感兴趣的可以了解一下

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

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

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

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;

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

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

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;

👉 常见做法:

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

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

async function loadExcelExport() {
  const { exportToExcel } = await import("./utils/excelExport");
  exportToExcel();
}

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

📌 建议实践:

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

到此这篇关于react代码分割的三种实现方法的文章就介绍到这了,更多相关react代码分割内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文