代码分割
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"));
```
最后更新于
这有帮助吗?