代码分割

Code Splitting

打包

  • 大多数 React 应用都会使用 Webpack、Rollup 或 Browserify 这类的构建工具来打包文件

  • 打包是一个将文件引入合并到一个单独文件的过程,最终形成一个 bundle,接着在页面上引入该 bundle,整个应用即可一次性加载

代码分割

  • 打包是一个非常棒的技术,但随着你得应用的增长,你的代码包也随之增长,尤其是在整合了体积巨大的第三方库的情况下,你需要关注你代码包中所含的代码,以避免因体积过大而导致加载时间过长。

  • 代码分割是诸如 Webpack、Rollup 和 Browserify 这类打包器支持的一项技术,能够创建多个包并在运行时动态加载

  • 对你的应用进行代码分割能够帮助你 “懒加载” 当前用户所需要的内容,能显著的提高你的应用性能

  • 尽管没有减少应用整体的代码体积,但你可以避免加载用户永远不需要的代码,并在初始加载的时候减少所需加载的代码量

import()

  • 在你的应用中引用代码分割的最佳方式是通过动态 import() 语法

    ```jsx harmony

// 使用之前 import { add } from './math';

console.log(add(16, 26));

// 使用之后 import("./math").then(math => { console.log(math.add(16, 26)) })

  • 此代码将会在组件首次渲染时,自动导入包含 OtherComponent 组件的包

  • React.lazy 接受一个函数,这个函数需要动态调用 import() 它必须返回一个 Promise 该 Promise 需要 reslove 一个 default export 的 React 组件

  • 然后应在 Suspense 组件中渲染 lazy 组件,如此使得我们可以使用在等待加载 lazy 组件时做优雅降级

    ```jsx harmony

import React, { Suspense } from 'react';

const OtherComponent = React.lazy(() => import('./OtherComponent'));

function MyComponent() { return ( Loading...}> </Suspense> </div> ); }

命名导出 Named Exports

  • React.lazy 目前只支持默认导出 default exports

    • 如果你想要引入的模块使用命名导出,你可以创建一个中间模块,开重新导出为默认模块

    • 保证 tree shaking 不会出错,并且不必引入不需要的组件

      ```jsx harmony

// ManyComponents.js export const MyComponent = / ... /; export const MyUnusedComponent = / ... /;

// MyComponent.js export { MyComponent as default } from "./ManyComponents.js";

// MyApp.js import React, { lazy } from 'react'; const MyComponent = lazy(() => import("./MyComponent.js"));

```

最后更新于

这有帮助吗?