ant design pro + umi4的动态菜单与动态路由

这篇具有很好参考价值的文章主要介绍了ant design pro + umi4的动态菜单与动态路由。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

困扰我好多天的自定义菜单及路由终于完成了,首先虽然看似为一个功能,但在umi4中是两项配置。

先说说我浪费了大量时间使用的处理方式:因为曾经的项目是umi3的,所以我就想原样搬过来,结果发现,布局页BasicLayout的子children不见了!

ant 动态菜单路由,前端,javascript,开发语言

ant 动态菜单路由,前端,javascript,开发语言 

 

如果这个子路由能正常显示,那引个ProLayout也就不用大费周章找其他方法。参考:https://blog.csdn.net/eisha2015/article/details/114831390

后来,我又找到了umi的patchRoutes,但发现怎么重写路由,菜单都没有变化。参考:https://blog.csdn.net/weixin_43294560/article/details/107447241

最后还是翻到ProComponents菜单的高级用法,才发现菜单直接在app.tsx里配置就行了,相当于这个文件就是当初的ProLayout。

之后还将子路由routes为[]时,把父结点也清除的数据处理,以及使用patchClientRoutes来修改默认路由跳转,而原本routes.ts配置的路转就可以删除了。

所以修改的代码如下:文章来源地址https://www.toymoban.com/news/detail-674196.html

type Router = {
  name?: string,
  path: string,
  icon?: string | React.ReactNode,
  routes?: Router[],
  component?: string,
  redirect?: string,
}

// routes为[],则删除结点
const deleteroutes = (arr: Router[]) => {
  let childs = arr
  for (let i = childs.length; i--; i > 0) {
    const routes = childs[i].routes;
    if (routes) {
      if (routes.length) {
        // 处理antd的图标,全部引入包的大小爆增,不如用iconfontUrl
        // const icon = childs[i].icon;
        // if (typeof icon === 'string') {
        //   childs[i].icon = React.createElement(Icons[icon]);
        // }
        deleteroutes(routes);
      } else {
        delete childs[i];
      }
    }
  }
  return JSON.parse(JSON.stringify(arr).replace(/null,/g, '').replace(/,null/g, '')) as Router[];
}

let extraRoutes: Router[];
export const patchClientRoutes = ({ routes }: any) => {
  const r = extraRoutes;
  const to = r![0].routes![0].routes![0].path;
  routes.unshift({
    path: '/',
    element: <Navigate to={to || ''} replace />,
  });
  r.forEach(element => {
    routes.unshift({
      path: element.path,
      element: <Navigate to={element.routes![0].routes![0].path} replace />,
    });
  });
};

export function render(oldRender: any) {
  setTimeout(() => {
    extraRoutes = deleteroutes([{
      name: '一级菜单A',
      path: '/a',
      routes: [
        {
          name: '二级菜单AA',
          path: '/a/aa',
          icon: 'icon1',
          routes: [
          ],
        },
        {
          name: '二级菜单BB',
          path: '/a/bb',
          icon: 'icon2',
          routes: [
            {
              name: '三级菜单AAA',
              path: '/a/aa/aaa',
              component: './a/aa/aaa',
            },
            {
              name: '三级菜单BBB',
              path: '/a/aa/bbb',
              component: './a/aa/bbb',
            },
          ],
        },
      ]
    },
    {
      name: '一级菜单B',
      path: '/b',
      routes: [
      ],
    }]);
    oldRender();
  }, 1000);
}

export const layout: RunTimeLayoutConfig = ({ initialState, setInitialState }) => {
  return {
    menu: {
      // 每当 initialState?.currentUser?.userid 发生修改时重新执行 request
      // params: {
      //   userId: initialState?.currentUser?.userid,
      // },
      request: async (params, defaultMenuData) => {
        return extraRoutes;
      }
    },
    .......
  };
};

到了这里,关于ant design pro + umi4的动态菜单与动态路由的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Ant Design Pro项目中 提示:找不到模块“@ant-design/pro-components”或其相应的类型声明

    Ant Design Pro中在使用 StatisticCard 指标卡组件时候,按照官方的文档从“@ant-design/pro-components”中引入这个组件发现会报错 提示找不到模块“@ant-design/pro-components”或其相应的类型声明 也就是说 Ant Design Pro 脚手架创建的项目中,默认没有引入这个依赖包,于是去package.json中看了

    2024年02月11日
    浏览(56)
  • 下载使用 ant design Pro 中遇到的一些问题

    npm v9.6.3 is known not to run on Node.js v19.9.0. This version of npm supports the following node versions: ^14.17.0 || ^16.13.0 || =18.0.0 . You can find the latest version at https://nodejs.org/. 需要更新npm版本 无法加载文件 F:nvmnodejstyarn.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.c

    2024年02月05日
    浏览(38)
  • umi4使用状态管理dva

    models/documentChange.ts

    2024年02月12日
    浏览(30)
  • 前端之vue 根据菜单自动生成路由(动态配置前端路由)

    在需要权限控制的页面,往往存在根据用户来显示菜单的情况,单独根据用户类型判断显然不是很好,如果后面用户类型发生变化,项目修改维护可能就会比较麻烦,所以比较好的做法是根据后端返回的菜单动态生成页面路由,以达到完全权限控制的目的,并且若权限发生变

    2024年04月10日
    浏览(29)
  • UMI4.0 无根目录,如何插入引用或节点

    UMI4.0 取消了根文件 document.ejs 手动添加这个文件到目录,也不会读取 需要在根目录引用第三方插件或者文件 在根目录新建文件 plugin.ts 在此文件中用 API 的方式插入节点 issue 链接:https://github.com/umijs/umi-next/issues/868 API文档:https://umijs.org/docs/api/plugin-api#addhtmlheadscripts 存在的问

    2024年02月10日
    浏览(30)
  • [绍棠] Ant Design Pro of Vue打包有前缀静态资源访问不到

    缺点:需要和部署的路径保持一致,不是很灵活 1、在环境变量.env中定义url前缀 2、定义vue路由前缀路径router/index.js 3、vue配置公共路径前缀vue.config.js 4、打包部署到nginx或其他中间件,此时要保证前缀和部署的前缀保持一致 nginx 1、使用history模式 2、定义vue路由前缀路径rout

    2024年02月11日
    浏览(42)
  • react--umi, 根据权限展示菜单,完成页面权限分配,以及路由鉴权

           umi框架,prolayout布局,access设置菜单权限,initialState全局初始化数据,配合使用,根据后端返回的权限信息,完成菜单的不同的权限的不同展示。     1. umi 配合 patlayout 布局, 实现根据配置的路由展示菜单栏     2. umi 的 access 插件,设置不同权限的菜单展示    

    2024年02月06日
    浏览(78)
  • Umi4 集成阿里低代码框架lowcode-engine

    最近准备研究下阿里低代码框架lowcode-engine, 官方Demo是提供好的脚手架,由于我们的框架使用的是umi,官方文档提供了一些教程,在此记录下在umi4集成lowcode-engine. 搭建umi4项目 1.通过官方文档的快速开始,我们可以快速创建出项目 先找个地方建个空目录 通过官方工具创建项目

    2024年02月08日
    浏览(30)
  • 小试Blazor——实现Ant Design Blazor动态表单

    前言 最近想了解下Blazor,于是尝试使用Blazor写一个简单的低代码框架,于是就采用了Ant Design Blazor作为组件库 低代码框架在表现层的第一步则是动态表单,需要将设计时的结构渲染成运行时的表单,本次主要实现动态表单,相关数据接口都以返回固定数据的形式实现 实现

    2024年02月10日
    浏览(36)
  • ant-design-pro-cli 运行pro create myapp报错Error [ERR_REQUIRE_ESM]: require() of ES Module是什么原因?

    根据官方文档全局安装了npm i @ant-design/pro-cli -g,然后运行pro create myapp,命令行出现: 这是什么原因导致的?

    2024年02月12日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包