如何使用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>
);
相关推荐
时寒的笔记5 分钟前
js逆向_webpack讲解加载器&酷某音乐案例
开发语言·javascript·webpack
李剑一13 分钟前
我做了个微信聊天模拟器,已开源
前端
yusirxiaer21 分钟前
为什么 markRaw 能修复 Vue 3 + ECharts 的 resize 报错
javascript·vue.js·echarts
代码搬运媛34 分钟前
30分钟带你从0手搓一个AI-Cli命令行工具
前端
赛博切图仔41 分钟前
前端性能内卷终点?Signals 正在重塑我们的开发习惯
前端·javascript·vue.js
小江的记录本43 分钟前
【RAG】RAG检索增强生成(核心架构、全流程、RAG优化方案、常见问题与解决方案)
java·前端·人工智能·后端·python·机器学习·架构
程序员buddha1 小时前
SCSS从0到1精通教程
前端·css·scss
ZC跨境爬虫1 小时前
海南大学交友平台登录页开发实战day6(覆写接口+Flask 本地链接正常访问)
前端·后端·python·flask·html
Highcharts.js1 小时前
抉择之巅:从2029年回望2026年——企业可视化“战略分水岭”?
前端·javascript·信息可视化·编辑器·echarts·highcharts
沙振宇1 小时前
【Web】使用Vue3+PlayCanvas开发3D游戏(十)让人物动起来
前端·游戏·3d·人物·