react-router-dom v6 useRoutes应用(懒加载多级路由)

5 篇文章 1 订阅
3 篇文章 0 订阅

软件定制,代码排错:小蓝阿姨的店铺



前言

如果没有本文章的需要,只是单纯用一下路由或者是想懒加载而已,直接看这篇即可:react-router-dom v6的路由懒加载形式,这里写了两种
本篇文章编辑环境:

对应的版本
react版本:18.0.0
react-dom版本:18.0.0
react-router-dom版本:6.3.0

由于上一篇写的不是特别好,我就直接重置了这一篇。
我就先附上代码了,这次写的比较简洁易懂。
整个路由的使用逻辑,其实和vue-router类似,本篇主要是懒加载。


这个v6版本的路由依赖
有这俩东西值得关注

import { useRoutes, Outlet } from 'react-router-dom'

使用useRoutes就可以写成对象形式的路由了,但是懒加载得额外处理
然后这个Outlet和vueRouter的router-view其实差不多,都是一个占位符的形式

代码

我是使用typescript进行编写的,有些类型需要写声明
所以我先贴上代码,需要的同学可以直接拷过去
首先这个组件就是整个路由的组件了,直接在最开始的地方调用这个组件就可以了,可以滑到文章写引入方式那里查看

// 声明类型
namespace SyncRoute{
  export type Routes = {
    path: string,
    component: React.LazyExoticComponent,
    children?: Routes[]
  }
}
// 这个主要是路由表组件的写法
import React, { Suspense, lazy } from 'react'
import { useRoutes, RouteObject } from 'react-router-dom'
const RouteTable: SyncRoute.Routes[] = [
  {
    path: '/',
    component: lazy(() => import('@/layout')),
    children: [
      {
        path: 'home',
        component: lazy(() => import('@/views/home')),
        children: [
          {
            path: 'about',
            component: lazy(() => import('@/views/home/components/about'))
          }
        ]
      }
    ]
  }
]

const syncRouter = (table: SyncRoute.Routes[]): RouteObject[] => {
  let mRouteTable: RouteObject[] = []
  table.forEach(route => {
    mRouteTable.push({
      path: route.path,
      element: (
        <Suspense fallback={ <div>路由加载ing...</div> }>
          <route.component />
        </Suspense>
      ),
      children: route.children && syncRouter(route.children)
    })
  })
  return mRouteTable
}

// 直接暴露成一个组件调用
export default () => useRoutes(syncRouter(RouteTable))


引入方式

上面代码那里实现完毕的组件。直接导入然后在你的入口文件里面使用就好了,
但是在使用前得注意,你的浏览器路由方式要先配一下,不然会报错
在这里插入图片描述
我这里就使用了hash的路由方式,也就是地址栏会出现一个#号

在这里插入图片描述
然后这每一级的写法其实和vue里面的无异,就是通过占位符(Outlet)进行操作的了,而这个占位符和router-view其实差不多,你会用vueRouter就会使用这玩意。
在这里插入图片描述


最终效果


在这里插入图片描述
在这里插入图片描述

  • 9
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
React Router v6 中,路由懒加载流程与 v5 有所不同。以下是实现路由懒加载的步骤: 1. 确保你已经安装了 `react-router-dom` 的版本为 6.x。 ```bash npm install react-router-dom@next ``` 2. 导入需要使用的组件和函数: ```jsx import React, { lazy, Suspense } from 'react'; import { BrowserRouter as Router, Route, Routes } from 'react-router-dom'; ``` 3. 创建需要懒加载的组件: ```jsx const Home = lazy(() => import('./components/Home')); const About = lazy(() => import('./components/About')); const Contact = lazy(() => import('./components/Contact')); ``` 4. 使用懒加载的组件和路由: ```jsx function App() { return ( <Router> <Suspense fallback={<div>Loading...</div>}> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="/contact" element={<Contact />} /> </Routes> </Suspense> </Router> ); } export default App; ``` 在上面的代码中,`Suspense` 组件用于在组件加载期间显示一个加载提示(例如 "Loading..."),直到组件加载完成。`fallback` 属性指定了加载期间显示的内容。 使用 `Routes` 组件来定义路由,而不是之前的 `Switch` 组件。 在每个 `Route` 组件中,使用 `element` 属性来指定要渲染的懒加载组件。 这样,当用户访问相应的路由时,对应的组件将会被动态加载并渲染。 请注意,v6 中还有其他一些变化,如路由路径匹配的语法和路由传参等。你可以查阅 React Router v6 的官方文档以获取更详细的信息。 希望这个例子对你有帮助!如果有任何问题,请随时向我提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小蓝阿姨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值