React懒加载(Hook版)

React.lazy
单页面(SAP)应用项目体积大了之后首次加载会出现时间过长导致的白屏,其实就是加载页面的时候还加载了一些当前页面根本用不到组件/js文件等。对bundle进行拆分使项目按需加载(懒加载),webpack支持代码拆分(code splitting)
项目最好都要加上

懒加载一般都会搭配React.Suspense使用,使懒加载实现得更加优雅。
因为直接使用React.lazy
const Views = lazy(() => import('../views')) <Views />
直接使用会报错:
image.png
这时候使用React.Suspense来配合做个 loading 或者占位符,就不会报错了。
注意:Suspense组件包裹lazy加载的组件

import { lazy, Suspense } from "react"
const TodoList = lazy(() => import('../views/TodoList'))
const Views = lazy(() => import('../views'))

return (
  <>
    <Suspense fallback={<>这里显示加载没完成时显示内同</>}>
      <Views />
    </Suspense>
    <Suspense fallback={<></>}>
      <TodoList />
    </Suspense>
  </>
)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值