React.lazy和Suspense组合实现组件懒加载

Posted guolizhi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了React.lazy和Suspense组合实现组件懒加载相关的知识,希望对你有一定的参考价值。

如何使用

React.lazy可以像渲染常规组件一样处理动态引入的组件

// 先定义一个Counter组件
export default function Counter (props) {
  return (
    <h1>count: {props.count}</h1>
  )
}

当我们使用这个Counter组件时,需要用一个Suspense来包裹,React.lazy接受一个函数作为参数,表明我们是动态引入了某个组件。引入时我们可以使用webpackChunkName来自定义打包之后的文件名。 需要注意的是如果一个组件是异步组件 ,那我们必须要用一个Suspense组件来包裹,并且传入一个fallback的函数作为参数,表示在加载动态组件的过程中,页面上如何显示。如果不进行以上操作,否则React会报错。

const Counter = React.lazy(() => import(/* webpackChunkName: "Counter" */ ‘./Counter‘))
function App() {
  return (
    <div className="App">
      <Suspense fallback={<div>loading...</div>}>
        <Counter count="12" />
      </Suspense>
    </div>
  );
}

以上是关于React.lazy和Suspense组合实现组件懒加载的主要内容,如果未能解决你的问题,请参考以下文章

React中异步模块api React.lazy和React.Suspense

使用 React Suspense 和 React.lazy 子组件进行 Jest/Enzyme 类组件测试

如何使用React.lazy和Suspense进行组件延迟加载

react懒加载(lazy, Suspense)

react懒加载(lazy, Suspense)

react懒加载(lazy, Suspense)