千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > 如何在React路由器中验证动态路由

如何在React路由器中验证动态路由

来源:千锋教育
发布人:syq
时间: 2022-09-14 17:08:25 1663146505

  在呈现组件之前获取并验证数据

31

  问题:

  为了说明这个问题,让我们以用户的配置文件为例。

  我会用一个参数定义动态路由,并呈现配置文件组件,在组件内部,我将从中获取,并在内部发出获取请求以获取用户信息。users/:userId userId useParams useEffect

32

  问题是,真的可以是任何东西。它可能是或...由于 React 在客户端执行所有操作,因此即使有人将 URL 更改为无效内容,页面组件也会呈现,例如,如果有人尝试访问已删除的用户配置文件的 URL。userId 12 hellomom users/hilol

  当然,拥有良好的结构非常重要,在获取数据时在页面组件中显示加载指示器,如果获取失败,则显示错误消息至关重要。但是,如果我们可以在渲染组件之前获取并验证数据呢?

  我的解决方案

  我构建了一个管理器组件,负责验证 fetch 响应是否正常,如果可以,则呈现页面组件,否则显示 404 页面。

  让我引导您完成代码。

  首先,我将页面组件包装在管理器组件中,如下所示:

33

  然后,我会向管理器传递一个名为 prop 的 prop,这是一个接收路由参数并返回 fetch 请求的函数。fetcher

  当用户进入页面时,将发生的第一件事是管理器将执行第一个useEffect,即执行验证的那个。仅当路径名不在 中时。invalidRoutesRef

  注意:每次挂载都会是空的,我建议你使用 Redux 或 React 上下文来存储,以避免验证路由徒劳无功。invalidRoutes

  我使用而不是简单地使用像 一样的标志的原因是,我注意到在导航到不同的配置文件后,其值将保留为“false”,因此即使 有效,页面也会显示404。invalidRoutesRef isValid isValid userId

34

  该函数首先将 设置为 true(Hint:默认将其设置为 true,以便在第一次渲染

tags:
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT
开班信息
北京校区
  • 北京校区
  • 大连校区
  • 广州校区
  • 成都校区
  • 杭州校区
  • 长沙校区
  • 合肥校区
  • 南京校区
  • 上海校区
  • 深圳校区
  • 武汉校区
  • 郑州校区
  • 西安校区
  • 青岛校区
  • 重庆校区
  • 太原校区
  • 沈阳校区
  • 南昌校区
  • 哈尔滨校区