react的ant-design-pro框架左侧菜单修改为动态路由
在使用 React 框架结合 Ant Design Pro 进行项目开发时,动态路由的修改是一项常见且重要的任务。动态路由能够根据用户的角色、权限或者其他运行时的条件来展示不同的页面内容,极大地提升了应用的灵活性和安全性。本文将结合一个完整的示例项目,详细介绍如何在 Ant Design Pro 中修改动态路由。
在 Ant Design Pro 中使用动态路由的好处包括:
- 灵活性:可以根据条件动态加载路由,适应不同的需求。
- 性能优化:结合懒加载减少初次加载时间,提高性能。
- 可维护性:路由和菜单管理清晰,易于管理和维护。
- 权限控制:可以根据用户角色控制访问权限,增强安全性。
- 用户体验:通过动态路由改善页面跳转体验,提高流畅性
动态路由都需要先在routes中注册页面,然后通过后端对比进行左侧菜单的显示。
下面又开看详细步骤吧!
一. 路由配置(通过access来进行权限验证)。在routes.ts中注册页面路由。
export default [{path: '/user',layout: false,routes: [{name: 'login',path: '/user/login',component: './User/Login',},],},// 首页{path: '/welcome',name: 'welcome',icon: 'HomeOutlined',component: './Welcome',layout: true,hideTitle: false,},// 门诊{path: '/admin',name: 'admin',icon: 'table',hideInBreadcrumb: true, // 添加这行,可以去掉父元素带子级的面包屑routes: [// 这第一个对象的作用就是当点击父级菜单时,默认重定向到父级下的第一个子菜单页面{path: '/admin',redirect: '/admin/sub-page',},// 门诊缴费记录{path: '/admin/sub-page',name: '门诊缴费记录',layout: false,component: './outpatient',},// 预约记录{path: '/admin/subscribe',name: '预约记录',// icon:'SnippetsFilled',layout: false,component: './Subscribe',},],},// 住院{name: 'list',icon: 'ReconciliationFilled',hideInBreadcrumb: true, // 添加这行,可以去掉父元素带子级的面包屑path: '/list',routes: [// 这第一个对象的作用就是当点击父级菜单时,默认重定向到父级下的第一个子菜单页面{path: '/list',redirect: '/list/hospital',layout: false,},// 住院缴费记录{path: '/list/hospital',name: '住院缴费记录',component: './HospitalPrice',layout: false,},// 房间管理{path: '/list/room',name: '房间管理',component: './Room',layout: false,},],},// 用户管理{name: 'user',icon: 'SnippetsFilled',hideInBreadcrumb: true, // 添加这行,可以去掉父元素带子级的面包屑path: '/user',routes: [// 这第一个对象的作用就是当点击父级菜单时,默认重定向到父级下的第一个子菜单页面{path: '/user/user',// redirect: '/user/user',name: '用户管理',component: './user',layout: false,},// 角色管理{path: '/user/role',name: '角色管理',component: './role',layout: false,},// 管理员管理{path: '/user/admin',name: '管理员管理',component: './Manage',layout: false,},// 就诊卡{path: '/user/card',name: '就诊卡',component: './Cards',layout: false,},],},// 科室管理{name: '科室管理',path: '/TableList',icon: 'DiffFilled',access: 'adminRouteFilter',component: './TableList',layout: true,},// 医院信息{name: 'hospital',icon: 'MedicineBoxFilled',hideInBreadcrumb: true, // 添加这行,可以去掉父元素带子级的面包屑path: '/hospital',routes: [// 这第一个对象的作用就是当点击父级菜单时,默认重定向到父级下的第一个子菜单页面{path: '/hospital',redirect: '/hospital/massage',},// 医生信息{path: '/hospital/massage',name: '医院信息',// icon:'SmileFilled',component: './HospitalMassage',layout: false,},// 医生管理{path: '/hospital/doctor',name: '医生管理',component: './DoctorOffice',layout: false,},// 排班管理{name: '医生排班管理',// icon: 'table',path: '/hospital/workforce',component: './workforce',layout: false,},// 标签管理{name: '标签管理',// icon: 'table',path: '/hospital/label',access: 'adminRouteFilter',component: './label',layout: false,},// 体检管理{name: '体检管理',// icon: 'table',path: '/hospital/physical',component: './physical',layout: false,},// 药品管理{name: '药品管理',// icon: 'table',path: '/hospital/drug',component: './drug',layout: false,},// 医院动态{name: '医院动态',// icon: 'table',path: '/hospital/dynamic',component: './dynamic',layout: false,},],},{path: '/',redirect: '/welcome',},{path: '*',layout: false,component: './404',},
];
二、动态路由实现步骤
1:配置路由访问权限(在routes.ts中给需要权限显示的路由添加:access)
// 科室管理{name: '科室管理',path: '/TableList',icon: 'DiffFilled',access: 'adminRouteFilter',component: './TableList',layout: true,},
2:权限控制(在access.ts中书写,需要根据自己的path进行修改)
// 动态路由控制
const adminRoutes = ['user', 'welcome', 'admin', 'list', 'TableList', 'hospital'];
const normalRoutes = ['user', 'list', 'TableList', 'hospital'];
const allUserRoutes = ['welcome'];export default function (initialState = {}) {// 取的当前账号const userInfo = JSON.parse(localStorage.getItem('user_account'));console.log('userInfo', userInfo);const isAdmin = userInfo === 'admin';const hasRoutes = isAdmin ? adminRoutes : normalRoutes;return {adminRouteFilter: () => isAdmin, // 只有管理员可访问normalRouteFilter: (route) => hasRoutes.includes(route.name), // initialState 中包含了的路由才有权限访问allUserRouteFilter: (route) => allUserRoutes.includes(route.name),};
}
分析权限控制代码:
1. 声明变量等于可以访问的菜单
const adminRoutes = ['user', 'welcome', 'admin', 'list', 'TableList', 'hospital'];
const normalRoutes = ['user', 'list', 'TableList', 'hospital'];
const allUserRoutes = ['welcome'];
2. 在登录页 存用户信息,用于对比
const userInfo = JSON.parse(localStorage.getItem('user_account'));console.log('userInfo', userInfo);
3. 在access.ts中取出来
// 取的当前账号const userInfo = JSON.parse(localStorage.getItem('user_account'));console.log('userInfo', userInfo);
4. 对比 可以访问的菜单
export default function (initialState = {}) {// 取的当前账号const userInfo = JSON.parse(localStorage.getItem('user_account'));console.log('userInfo', userInfo);const isAdmin = userInfo === 'admin';const hasRoutes = isAdmin ? adminRoutes : normalRoutes;return {adminRouteFilter: () => isAdmin, // 只有管理员可访问normalRouteFilter: (route) => hasRoutes.includes(route.name), // initialState 中包含了的路由才有权限访问allUserRouteFilter: (route) => allUserRoutes.includes(route.name),};
}
相关文章:
react的ant-design-pro框架左侧菜单修改为动态路由
在使用 React 框架结合 Ant Design Pro 进行项目开发时,动态路由的修改是一项常见且重要的任务。动态路由能够根据用户的角色、权限或者其他运行时的条件来展示不同的页面内容,极大地提升了应用的灵活性和安全性。本文将结合一个完整的示例项目ÿ…...

【教程】Windows通过网线共享网络给其它设备
转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 1、打开“控制面板”。 2、点击“网络和共享中心”。 3、点击“更改适配器设置”。 4、选中要共享的网络适配器,右击选中“属性”。 5、勾选…...

百度AI开发者大会:连发多款AI应用,覆盖AI数字人等热门赛道
4月25日,Create2025百度AI开发者大会在武汉隆重举办。百度创始人李彦宏发表了题为《模型的世界 应用的天下》的演讲。60分钟的演讲中,李彦宏发布了两大模型,多款热门AI应用,并宣布将帮助开发者全面拥抱MCP。 当天发布的文心大模型…...

Java 线程的六种状态与完整生命周期详解
🚀 Java 线程的几种状态详解 在 Java 中,线程状态(Thread State)是由 Thread.State 枚举定义的,总共有六种: 状态含义典型场景示例NEW新建状态,线程对象刚创建,还未调用 start() 方…...

05--Altium Designer(AD)的详细安装
一、软件的下载 Altium Designer官网下载 1、临近五一的假期,想着搞个项目,且这个项目与PCB有关系,所以就下这个软件来玩玩。下面保姆级教大家安装。 2、选择适合自己的版本下载(我安装的是24的) 3、软件安装 1.下…...
2:QT联合HALCON编程—图像显示放大缩小
1.声明事件 #include <HalconCpp.h> using namespace HalconCpp;#include <QCloseEvent>//滚轮事件 2.在.h文件中声明和定义公共全局变量,以及图像缩放的函数 void wheelEvent(QWheelEvent *event);//定义函数HTuple wcRow0, wcRow1, wcCol0, wcCol1,m…...

Java 队列与阻塞队列全面解析:从 Queue 到 TransferQueue 的实现与应用
文章目录 Queue队列QueueDeque 阻塞队列BlockingQueueArrayBlockingQueueLinkedBlockingQueuePriorityBlockingQueueSynchronousQueueDelayQueue BlockingDequeLinkedBlockingDeque TransferQueueLinkedTransferQueue Queue Queue(队列)是一种特殊的线性…...
服务器虚拟化:技术解析与实践指南
在信息技术飞速发展的今天,企业对服务器资源的需求日益增长,传统物理服务器存在资源利用率低、部署周期长、管理成本高等问题。服务器虚拟化技术应运而生,它通过将物理服务器的计算、存储、网络等资源进行抽象和整合,划分成多个相互隔离的虚拟服务器,从而提高资源利用率、…...

【蓝桥杯省赛真题56】Scratch抓不住的蜜蜂 蓝桥杯scratch图形化编程 中小学生蓝桥杯省赛真题讲解
目录 scratch抓不住的蜜蜂 一、题目要求 1、准备工作 2、功能实现 二、案例分析 1、角色分析 2、背景分析 3、前期准备 三、解题思路 四、程序编写 五、考点分析 六、推荐资料 1、scratch资料 2、python资料 3、C++资料 scratch抓不住的蜜蜂 第十五届青少年蓝桥…...
线程池(二):深入剖析synchronized关键字的底层原理
线程池(二):深入剖析synchronized关键字的底层原理 线程池(二):深入剖析synchronized关键字的底层原理一、基本使用1.1 修饰实例方法1.2 修饰静态方法1.3 修饰代码块 二、Monitor2.1 Monitor的概念2.2 Moni…...
【线段树】P8539 「Wdoi-2」来自地上的支援|普及+
P8539 「Wdoi-2」来自地上的支援 题目背景 波光粼粼的山顶湖与庄严神圣的神社之下,是一座复合型活火山。 沿幻想风穴而下,便能到达火山之下,废弃已久的地狱原址。 在旧地狱中,有一座大都市。那里是旧地狱还是地狱的时候在那工作…...

《TCP/IP详解 卷1:协议》之第七、八章:Ping Traceroute
目录 一、ICMP回显请求和回显应答 1、ICMP回显请求 2、ICMP回显应答 二、ARP高速缓存 三、IP记录路由选项(Record Route,RR) 1、记录路由选项的工作过程 2、RR 选项的 IP 头部格式 2.1、RR 请求 2.2、RR响应 四、ping 的去返路径 五…...
Leetcode:1. 两数之和
题目 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。 你可以按任意顺序返回答案。 示…...
【Java学习笔记】冒泡排序
冒泡排序 思想:经过一轮遍历比较,把最大的放在数组的末尾 int[] a {3, 2, 1}; for( int i 0; i < a.length-1; i){for( int j 0; j < a.length-1-i; j){if(a[j] > a[j1]){int temp a[j];a[j] a[j1];a[j1] temp;}} } for( int i 0; i &…...
【数字图像处理】立体视觉基础(2)
相机标定 【1】相机标定的概念 相机参数:相机成像的几何模型的参数 相机标定:求解参数的过程 【2】相机标定的作用 (1)求出相机的内、外参数,以及畸变参数 (2)校正镜头畸变影响,…...

NtripShare 2025第一季度主要技术进展
GNSS方面 1、开源GNSS接收机配置软件基础版本。 2、商业版本GNSS接收机配置软件,增加PPP、文件保存、前端解算(静态、RTK-Static),前端坐标转换。 3、GNSS接收机配置软件全面适配米尔T133i硬件方案。 视觉检测方面 1、做出第…...

头歌实训之存储过程、函数与触发器
🌟 各位看官好,我是maomi_9526! 🌍 种一棵树最好是十年前,其次是现在! 🚀 今天来学习C语言的相关知识。 👍 如果觉得这篇文章有帮助,欢迎您一键三连,分享给更…...

【华为】防火墙双击热备-之-主备模式-单外网线路-分享
FW1和FW2的业务接口都工作在三层,上行连接二层交换机。上行交换机连接运营商的接入点,运营商为企业分配的IP地址为100.100.100.2。现在希望FW1和FW2以主备备份方式工作。正常情况下,流量通过FW1转发;当FW1出现故障时,流…...
c++ package_task
int print_sum(int a, int b) {std::cout << a << " " << b << " " << (a b) << std::endl;return a b; }int main() {// 创建绑定后的可调用对象auto print_sum_5 std::bind(print_sum, 5, 6);// 包装为 packag…...
基于计算机视觉的行为检测:从原理到工业实践
一、行为检测的定义与核心价值 行为检测(Action Recognition)是计算机视觉领域的关键任务,旨在通过分析视频序列理解人类动作的时空特征。其核心价值体现在时序建模和多尺度分析能力上——系统需要捕捉动作的起始、发展和结束全过程,同时适应不同持续时间(0.1秒至数分钟)…...

川翔云电脑32G大显存集群机器上线!
川翔云电脑今日重磅推出32G 大显存机型,为游戏玩家、设计师、AI 开发者等提供极致云端算力体验! 一、两大核心配置,突破性能天花板 ✅ 32G 超大显存机型 行业领先:搭载 NVIDIA 专业显卡,单卡可分配 32G 独立显存&am…...

加里·基尔代尔:CP/M之父与个人计算时代的先驱
名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 加里基尔代尔:CP/M之父与个人计算时代的先驱 一、早年生活与教育背景 1.…...

静态多态和动态多态的区别
C多态机制深度解析 多态是面向对象编程的核心特性,允许通过统一接口执行不同实现。在C中,多态表现为基类指针或引用调用虚函数时,根据实际对象类型执行对应派生类的函数逻辑。 基础实现示例 定义基类与派生类,演示动态绑定…...
MQL5教程 06 EA开发实战
文章目录 一、调用多指标多周期EA示例二、获取ZigZag顶点值三、逆势加仓EA 一、调用多指标多周期EA示例 shuju.mqh: class shuju{public:shuju(){} ~shuju(){}void MA(double &ma[],int count,string symbol, // 交易品种名称 ENUM_TIMEFRA…...
LLaMa Factory大模型微调
LLaMa Factory大模型微调 大模型微调平台&硬件LLaMA-Factory安装hfd下载hugging face模型自我认知微调Alpaca数据集指令监督微调断点续训 大模型微调 微调自我认知微调特定领域数据集。 平台&硬件 Ubuntu20.04显卡:M40 24G 2080TI 22G微调框架ÿ…...

Burp靶场JWT学习笔记1
JWT(JSON Web Token) 从其名字就可以看出来,它具有表示身份的作用,其本质是将用户信息储存到一串json字符串中再将其编码得到一串token JWT由三部分组成,分别是 Header,Payload,Signatrue JWTBase64(Header).Base6…...

C++?类和对象(下)!!!
一、前言 在之前我们已经讨论过了有关类和对象的前置知识以及类中的六大默认成员函数,在本期我们继续再讨论类和对象中剩余的友元、初始化列表等相关知识,如果需要再了解之前的知识的话,链接奉上:C?类和对象࿰…...

FastAPI 零基础入门指南:10 分钟搭建高性能 API
一、为什么选择 FastAPI? 想象一下,用 Python 写 API 可以像搭积木一样简单,同时还能拥有媲美 Go 语言的性能,这个框架凭借三大核心优势迅速风靡全球: 开发效率提升 3 倍:类型注解 自动文档,…...
prometheus通过Endpoints自定义grafana的dashboard模块
1、prometheus自定义的dashboard模块 文件路径/etc/prometheus/config_out/prometheus-env.yaml - job_name: serviceMonitor/monitoring/pfil/0honor_labels: falsekubernetes_sd_configs:- role: endpointsnamespaces:names:- monitoringrelabel_configs:- source_labels:- …...

机器人新革命:Pi 0.5如何让智能走进千家万户
在科技飞速发展的今天,机器人技术正在以一种令人惊喜的方式贴近我们的生活。最近,Physical Intelligence 公司推出了 Pi 0.5 版本,这一创新设计不仅颠覆了传统机器人的运作模式,更让我们看到了未来智能设备融入日常生活的无限可能…...