Umi 4 特性 02:React Router 6 和新路由

简介: Umi 4 特性 02:React Router 6 和新路由
🙋🏻‍♀️ 编编拎重点:之前给大家分享了蚂蚁集团前端工程师云谦关于 Umi 4 新特性系列分享的第一篇👉🏻Umi 4 特性 01:MFSU V3,比 Vite 还要快 今天给大家带来的是第二篇,后续将陆续更新 Umi 4 的其他新特性,欢迎关注不迷路~

React Router 6


React Router 是 Umi 的重要依赖,Umi 基于此实现路由功能,Umi 4 从 React Router 5 升级到了 React Router 6。


我个人太喜欢 React Router 6 这个版本了。大家应该都听说过 Remix 框架,和 React Router 出自同一个团队。由于他们自己也要做框架,所以 React Router 6 面向框架也做了很多优化,基于此,Umi 删了好多路由渲染和请求策略类的代码,因为这些在 React Router 中已内置处理。


大版本意味着 Break Change,而且还不少(链接:https://reactrouter.com/docs/en/v6/upgrading/v5。但对于 Umi 用户来说,却又不多。因为我们之前使用 React Router 的方式是有节制的,比如没有开放 Route、Routes 和 Switch 的使用。以下是一些值得注意的 Break Change。


1、父路由渲染子路由,之前是 props.children,现在是 <Outlet />2、之前路由组件 props 里能拿到的 location、history、match 等信息,现在可通过 useRouteData() 获取(好处是 props 只能在当前路由组件中获取,而 hooks 的方式在子组件中也能使用,减少了 props 的传递)


其他会在框架层做兼容。

新路由


除了 React Router 6,我们对内部路由的数据结构也做了调整。


- 文件/配置 ➡ routes ➡ 渲染

+ 文件/配置 ➡ routesById ➡ routes ➡ 渲染


数据结构从 routes 变成了 routesById。前者是嵌套的,[{ id: 'a', children: [{ id: 'b' }] }];后者是拍平的,[{ id: 'a' }, { id: 'b', parentId: 'a' }]。拍平对于 Umi Contributor 或插件开发者来说,意味着修改路由更容易,不再需要递归去找。比如添加一个全局路由,找到没有 parentId 的加上一个即可;在路由上 set 和 get 数据也更简单。


同时拍平的路由是按 path 长度排序的,长的在前。这让路由匹配更简单,由于父路由的 path 肯定比子路由短,所以最先匹配到的肯定是子路由。


停!这些对于 Umi 用户来说有啥意义?


我的理解是扩展能力和想象空间。比如下一篇会介绍的「默认最快的请求」、SSR/SSG 的「loader + useLoader」,规划中的「Form + Action + useTransition」、「基于 Link 的请求 prefetch」等,都因这个调整而变得更简单。再比如如果要自行实现布局、菜单时会需要做路由匹配之类的事,也会更容易。


以路由为中心


之后,会有更多以路由为中心的功能出现。


Umi 3 就有不少功能是围绕着路由搭建的,比如埋点、菜单、权限、标题等。Umi 4 中会有更多,比如客户端请求、服务端请求、处理表单提交等。

// 路由组件
export default function() {
  useLoaderData()
  useClientLoaderData()
  useTransition()
}
// 客户端请求
export function clientLoader() {}
// 服务端请求
export function loader() {}
// 处理表单提交
export function action() {}

对于 Umi 用户来说有变更成本,但带来的好处也很多。1)对于团队而言的编码一致性,在统一的地方编码,不要 useEffect、useState、useXXX;2)框架发挥更大价值,举个例子,比如通过静态分析路由组件,提取和拆分 loader、clientLoader 等子方法,可以让页面以我们理解最快的方式渲染(这部分在下一篇展开)。


参考:

https://reactrouter.com/docs/en/v6/upgrading/v5

https://remix.run/blog/remixing-react-router

相关文章
|
2月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
190 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
22天前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
38 1
|
24天前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
31 2
React——路由Route
|
1月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
229 19
|
1月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
33 2
|
1月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
34 1
|
2月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
57 4
React技术栈-React路由插件之自定义组件标签
|
2月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
90 3
|
2月前
|
前端开发 程序员 API
React技术栈-React路由插件之react-router的基本使用
这篇博客介绍了React路由插件react-router的基本使用,包括其概念、API、以及如何通过实战案例在React应用中实现SPA(单页Web应用)的路由管理。
75 9
|
3月前
|
前端开发 测试技术 开发者
React Router的神奇之处:如何用导航与路由管理让你的复杂SPA飞起来?
【8月更文挑战第31天】本文全面解析了React Router——一款用于React应用的路由与导航管理库。通过定义不同路径并依据URL渲染组件,React Router支持路径匹配、参数路由及嵌套路由等多种模式。文章详细介绍了其基本与高级用法,如使用`Link`组件导航、`Switch`组件进行路径匹配及`NavLink`自定义活动链接样式。此外,还探讨了懒加载、代码分割等性能优化技巧,并提供了简单示例代码,帮助读者快速上手。遵循本文最佳实践,开发者能够更高效地利用React Router构建复杂的单页面应用。
81 0
下一篇
无影云桌面