如何使用react-router实现动态路由

前言

最近在写自己的个人网站,需要实现一个动态菜单的功能,大致想法是,后端返回登录用户拥有权限菜单,前端根据菜单动态的创建路由。这样前端就不需要本地配置路由表了。

原理

借助vite的import.meta.glob<{ default: React.ComponentType<any> }>('../pages/**/*.tsx');方法动态导入组件。通过这个方法,我们可以拿到文件路径和文件模块的对象,如下图所示:

我们可以配合React的lazy函数,实现组件的动态导入。

其中shouldAddRoutes是后端传来的登录用户的菜单列表,这样我们就能实现前端路由的动态导入了。

主要代码

tsx 复制代码
// 通过vite引入Pages下所有的tsx文件
const modules = import.meta.glob<{ default: React.ComponentType<any> }>('../pages/**/*.tsx');
// 在权限列表中获取当前用户权限,本系统使用zustand进行保存
const { menus } = usePermissionStore(); 
// 筛选出需要添加路由的菜单
const shouldAddRoutes = menus.filter((m) => m.path && m.component);
const routes = [
  ...DEFAULT_ROUTER,
  {
    path: '/',
    element: <BaseLayout />,
    errorElement: <ErrorPage />,
    children: shouldAddRoutes.length
      ? [
          {
            path: '/',
            element: <Home />,
            index: true,
          },
          {
            path: '/un-auth',
            element: <UnAuthPage />,
          },
          ...shouldAddRoutes.map((route) => {
            // 根据路径获取组件,这里只使用了Component,如需要也可以配合react-router的loader
            const Component = lazy(modules[route.component]);
            return {
              path: route.path,
              handle: {
                title: route.name,
              },
              element: <Component />,
            };
          }),
        ]
      : [],
  },
  {
    path: '*',
    element: <NotFoundPage />,
  },
];
const router = createBrowserRouter(routes);

return (
  <Suspense fallback={<LoadingPage message="loading..." />}>
    <RouterProvider router={router} />
  </Suspense>
);
相关推荐
Mintopia6 分钟前
🤖 AI 决策 + 意图OS:未来软件形态的灵魂共舞
前端·人工智能·react native
攀登的牵牛花7 分钟前
前端向架构突围系列 - 框架设计(四):依赖倒置原则(DIP)
前端·架构
Van_Moonlight7 分钟前
RN for OpenHarmony 实战 TodoList 项目:已完成未完成数量显示
javascript·开源·harmonyos
程序员爱钓鱼15 分钟前
Node.js 编程实战:测试与调试 —— 日志与监控方案
前端·后端·node.js
Mapmost23 分钟前
数字孪生项目效率翻倍!AI技术实测与场景验证实录
前端
小酒星小杜27 分钟前
在AI时代,技术人应该每天都要花两小时来构建一个自身的构建系统-Input篇
前端·程序员·架构
Cache技术分享35 分钟前
290. Java Stream API - 从文本文件的行创建 Stream
前端·后端
陈_杨38 分钟前
前端成功转鸿蒙开发者真实案例,教大家如何开发鸿蒙APP--ArkTS 卡片开发完全指南
前端·harmonyos
小杨同学4944 分钟前
C 语言实战:枚举类型实现数字转星期(输入 1~7 对应星期几)
前端·后端
陈_杨1 小时前
前端成功转鸿蒙开发者真实案例,教大家如何开发鸿蒙APP--ArkTS 卡片刷新机制
前端·harmonyos