如何使用

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>
  );
}

相关文章:

  • 2021-07-30
  • 2022-12-23
  • 2021-11-27
  • 2021-12-01
  • 2022-12-23
  • 2022-12-23
  • 2021-11-26
猜你喜欢
  • 2022-01-02
  • 2022-12-23
  • 2021-05-20
  • 2022-01-08
  • 2021-12-18
  • 2022-01-21
相关资源
相似解决方案