如何使用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>
);
相关推荐
工一木子28 分钟前
URL时间戳参数深度解析:缓存破坏与前端优化的前世今生
前端·缓存
半点寒12W2 小时前
微信小程序实现路由拦截的方法
前端
某公司摸鱼前端3 小时前
uniapp socket 封装 (可拿去直接用)
前端·javascript·websocket·uni-app
要加油哦~3 小时前
vue | 插件 | 移动文件的插件 —— move-file-cli 插件 的安装与使用
前端·javascript·vue.js
小林学习编程3 小时前
Springboot + vue + uni-app小程序web端全套家具商场
前端·vue.js·spring boot
柳鲲鹏3 小时前
WINDOWS最快布署WEB服务器:apache2
服务器·前端·windows
weixin-a153003083164 小时前
【playwright篇】教程(十七)[html元素知识]
java·前端·html
ai小鬼头4 小时前
AIStarter最新版怎么卸载AI项目?一键删除操作指南(附路径设置技巧)
前端·后端·github
wen's5 小时前
React Native 0.79.4 中 [RCTView setColor:] 崩溃问题完整解决方案
javascript·react native·react.js
一只叫煤球的猫5 小时前
普通程序员,从开发到管理岗,为什么我越升职越痛苦?
前端·后端·全栈