react - 根据路由生成菜单

后端返回菜单的格式
javascript 复制代码
menuList:[
        {
          index: true,
          name: "",
          component: "../views/Home",
          meta: { title: "首页", requiresAuth: true,roles:['user']},
        },
        {
          path: "/admin",
          name: "admin",
          meta: { title: "管理页", roles: ["admin"] },
          children: [
            {
              path: "/admin/user",
              name: "User",
              component: "@/pages/Admin/User",
              meta: { title: "用户管理" },
              children: [
            {
              path: "/admin/user",
              name: "User",
              component: "@/pages/Admin/User",
              meta: { title: "用户管理1" },
            },
          ],
            },
          ],
        },
      ],

递归转换 menuList 为 Ant Design Menu 的 items 格式

javascript 复制代码
const convertMenuListToItems = (menuList: any[]): MenuItem[] => {
  return menuList.map((menu) => {
    const item: any = {
      key: menu.path || menu.name, // 使用 path 或 name 作为 key
      label: menu.meta?.title || menu.name, // 显示标题
    };
 
    // 如果有子菜单,递归处理
    if (menu.children) {
      item.children = convertMenuListToItems(menu.children);
    }
 
    // 如果是 index 路由,可以标记特殊 key(可选)
    if (menu.index) {
      item.key = 'home'; // 强制指定 key,避免重复
    }
 
    return item;
  });
};






const Menu1: React.FC = () => {
  const { menuList } = useBoundStore()
const items =convertMenuListToItems(menuList)

  const [current, setCurrent] = useState('mail');

  const onClick: MenuProps['onClick'] = (e) => {
    console.log('click ', e);
    setCurrent(e.key);
  };

  return <Menu onClick={onClick} selectedKeys={[current]} mode="horizontal" items={items} style={{display:'flex',justifyContent:'center',alignItems:'center'}}/>;
};

export default Menu1;
相关推荐
大雷神40 分钟前
站在JS的角度,看鸿蒙中的ArkTs
开发语言·前端·javascript·harmonyos
Bdygsl2 小时前
前端开发:JavaScript(3)—— 选择与循环
开发语言·javascript·ecmascript
杨荧6 小时前
基于大数据的美食视频播放数据可视化系统 Python+Django+Vue.js
大数据·前端·javascript·vue.js·spring boot·后端·python
cmdyu_6 小时前
如何解决用阿里云效流水线持续集成部署Nuxt静态应用时流程卡住,进行不下去的问题
前端·经验分享·ci/cd
WordPress学习笔记6 小时前
根据浏览器语言判断wordpress访问不同语言的站点
前端·javascript·html
yuanmenglxb20046 小时前
解锁webpack核心技能(二):配置文件和devtool配置指南
前端·webpack·前端工程化
鲸落落丶7 小时前
JavaScript构建工具
javascript
JefferyXZF7 小时前
Next.js 路由导航:四种方式构建流畅的页面跳转(三)
前端·全栈·next.js
啃火龙果的兔子7 小时前
React 多语言(i18n)方案全面指南
前端·react.js·前端框架
阿奇__7 小时前
深度修改elementUI样式思路
前端·vue.js·elementui