当前位置: 首页 > article >正文

别再硬编码了!用Vue Router + el-menu动态生成后台管理系统左侧菜单(附完整代码)

Vue Router与el-menu深度整合打造企业级动态菜单解决方案后台管理系统开发中左侧菜单栏的动态渲染是个高频痛点。想象一下这样的场景每次新增功能模块都要手动修改菜单代码不同角色看到的菜单项需要差异化展示菜单激活状态总是不准确...这些问题消耗了开发者大量精力。本文将彻底解决这些痛点通过Vue Router与Element UI的el-menu组件深度整合实现一套可复用的动态菜单解决方案。1. 动态菜单架构设计动态菜单的核心在于数据驱动。我们需要设计一套前后端协同的菜单数据结构同时考虑路由配置的匹配关系。以下是经过多个项目验证的推荐方案菜单数据结构示例{ id: user-management, title: 用户管理, icon: el-icon-user, path: /system/users, children: [ { title: 用户列表, path: /system/users/list, permission: user:view } ] }关键设计原则菜单项与路由路径保持一一对应使用嵌套结构支持多级菜单包含权限标识字段实现菜单过滤图标字段兼容Element UI图标体系提示路径命名建议采用kebab-case风格与Vue Router的命名规范保持一致2. 路由配置与菜单绑定传统方案中路由和菜单是分离配置的这会导致维护困难。我们采用声明式路由配置将菜单元数据直接嵌入路由定义// router.js const routes [ { path: /system, component: Layout, meta: { title: 系统管理, icon: el-icon-s-tools, alwaysShow: true // 即使只有一个子路由也显示父菜单 }, children: [ { path: users, component: () import(/views/system/users), meta: { title: 用户管理, icon: el-icon-user, permissions: [user:view] } } ] } ]路由配置优化技巧使用meta字段存储菜单相关属性通过alwaysShow控制父级菜单显示逻辑权限标识与后端权限系统保持一致动态导入组件提升性能3. 动态菜单组件实现基于上述设计我们可以创建智能菜单组件。以下是核心实现代码template el-menu :default-activeactiveMenu :collapseisCollapse :unique-openedtrue router selecthandleSelect sidebar-item v-forroute in permissionRoutes :keyroute.path :itemroute :base-pathroute.path / /el-menu /template script import SidebarItem from ./SidebarItem export default { components: { SidebarItem }, computed: { permissionRoutes() { return this.$store.state.permission.routes }, activeMenu() { const route this.$route const { meta, path } route return meta?.activeMenu || path } } } /script递归菜单项组件template template v-if!item.hidden el-submenu v-ifhasChildren :indexresolvePath(basePath) template #title i :classitem.meta.icon / span{{ item.meta.title }}/span /template sidebar-item v-forchild in item.children :keychild.path :itemchild :base-pathresolvePath(child.path) / /el-submenu el-menu-item v-else :indexresolvePath(basePath) i :classitem.meta.icon / template #title{{ item.meta.title }}/template /el-menu-item /template /template4. 高级功能实现4.1 精准菜单激活控制el-menu的router模式有时无法满足复杂场景的激活状态需求。我们需要增强激活逻辑// 在Sidebar组件中 computed: { activeMenu() { const route this.$route const { meta, path } route // 处理详情页返回列表页保持激活状态 if (meta.activeMenu) { return meta.activeMenu } // 处理带参数的路径 if (path.includes(/:) || path.includes(?)) { return path.split(/[/:?]/)[0] } return path } }4.2 权限过滤实现结合Vuex实现菜单权限过滤// permission.js function filterAsyncRoutes(routes, roles) { return routes.filter(route { if (route.meta?.permissions) { return roles.some(role route.meta.permissions.includes(role)) } return true }) }4.3 菜单状态持久化使用localStorage保存菜单展开状态// 在Sidebar组件中 watch: { isCollapse(val) { localStorage.setItem(sidebarCollapse, val) } }, mounted() { const saved localStorage.getItem(sidebarCollapse) if (saved ! null) { this.isCollapse saved true } }5. 性能优化方案大型系统中菜单可能包含数百项需要特别关注性能优化策略实现方式效果路由懒加载component: () import(./views/...)减少初始加载体积菜单缓存keep-alive包裹动态组件避免重复渲染虚拟滚动使用el-scrollbar自定义实现减少DOM节点数按需加载分接口获取不同模块菜单降低初始请求量// 虚拟滚动实现示例 el-scrollbar wrap-classscrollbar-wrapper el-menu !-- 只渲染可视区域内的菜单项 -- /el-menu /el-scrollbar style .scrollbar-wrapper { overflow-x: hidden !important; max-height: calc(100vh - 100px); } /style6. 常见问题解决方案菜单闪烁问题// 在App.vue中 template div v-show!isRouterAlive router-view v-ifisRouterAlive / /div /template script export default { provide() { return { reload: this.reload } }, methods: { reload() { this.isRouterAlive false this.$nextTick(() (this.isRouterAlive true)) } } } /script菜单项重复渲染// 在路由配置中 { path: /redirect, component: Layout, hidden: true, children: [ { path: /redirect/:path(.*), component: () import(/views/redirect) } ] }图标加载优化// 创建icon组件 template svg-icon v-ifisSvg :icon-classicon / i v-else :classicon / /template script export default { props: { icon: { type: String, required: true } }, computed: { isSvg() { return this.icon.startsWith(svg-) } } } /script在多个中大型后台管理系统项目中实践这套方案后菜单相关的维护工作量减少了约70%权限控制的错误率降低了90%。特别是在需要频繁调整菜单结构的敏捷开发环境中这种动态方案展现出了巨大优势。

相关文章:

别再硬编码了!用Vue Router + el-menu动态生成后台管理系统左侧菜单(附完整代码)

Vue Router与el-menu深度整合:打造企业级动态菜单解决方案 后台管理系统开发中,左侧菜单栏的动态渲染是个高频痛点。想象一下这样的场景:每次新增功能模块都要手动修改菜单代码,不同角色看到的菜单项需要差异化展示,菜…...

动手抓波形:用逻辑分析仪实测PCI总线读时序,对照协议看信号变化

实战PCI总线时序分析:用逻辑分析仪捕捉读操作关键信号 在硬件开发与调试过程中,理解总线协议与实际信号波形之间的关系是一项核心技能。PCI总线作为曾经广泛使用的并行总线标准,其严谨的时序规范至今仍是学习总线协议的经典案例。本文将带您走…...

当BAPI_ACC_DOCUMENT_POST搞不定时,试试SAP的“内部过账接口”:POSTING_INTERFACE_DOCUMENT实战教程

当BAPI_ACC_DOCUMENT_POST受限时:深入解析SAP内部过账接口POSTING_INTERFACE_DOCUMENT 在SAP财务模块开发中,BAPI_ACC_DOCUMENT_POST常被视为创建会计凭证的"标准答案",但资深ABAP开发者都知道,当遇到特殊总账标识&…...

Windows Server 2019/2022 部署 Redmine 5.0.0 生产环境指南:从安装到邮件通知全搞定

Windows Server 2019/2022 企业级 Redmine 5.0.0 生产环境部署实战 在企业级项目管理工具的选择中,Redmine以其开源灵活的特性成为许多技术团队的首选。不同于个人开发环境的简易部署,生产环境下的Redmine需要更高的稳定性、安全性和可维护性。本文将带您…...

在CentOS 7.6上,用Python 3.8和Docker 24.0.7搞定DataHub 0.12.0部署(保姆级避坑实录)

在CentOS 7.6上精准部署DataHub 0.12.0的全流程避坑指南 当你面对一台全新的CentOS 7.6服务器,想要部署DataHub 0.12.0时,可能会遇到各种意想不到的"坑"。本文将从零开始,带你一步步完成Python 3.8.18、Docker 24.0.7等特定版本的…...

番茄小说下载器完整教程:3分钟打造个人离线图书馆

番茄小说下载器完整教程:3分钟打造个人离线图书馆 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 你是否在地铁上因为网络信号差而无法继续阅读小说?是…...

开源会话分析器实战:从数据埋点到自动化脚本优化

1. 项目概述与核心价值 最近在折腾一个很有意思的开源项目,叫 arkbuilder/open-claw-session-analyzer 。乍一看这个项目名,可能会觉得有点抽象,什么“Open Claw”、“Session Analyzer”,听起来像是某种数据分析工具。但如果你…...

告别商家固件依赖:手把手教你为全志H3开发板编译并移植Qt 5.12.9运行环境

全志H3开发板深度定制:从零构建Qt 5.12.9嵌入式运行环境实战指南 当开发板商家的预装系统无法满足项目需求时,真正的嵌入式开发者需要掌握自主构建完整软件栈的能力。本文将带你深入全志H3平台,从交叉编译环境搭建到Qt库深度裁剪&#xff0c…...

绝地求生玩家必看:罗技鼠标宏智能压枪配置指南

绝地求生玩家必看:罗技鼠标宏智能压枪配置指南 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 还在为绝地求生(PUBG&…...

WeChatExporter终极指南:免费导出微信聊天记录的完整解决方案

WeChatExporter终极指南:免费导出微信聊天记录的完整解决方案 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾因手机损坏而丢失重要的微信工作对话&a…...

Qt Creator里玩转多项目(.pro)开发:从独立应用到动态库,一个解决方案搞定所有子模块

Qt Creator多项目管理实战:从独立应用到动态库的完整解决方案 在复杂的软件开发中,单一项目往往难以满足产品需求。当你的产品需要同时包含GUI应用、后台服务和共享功能库时,如何高效管理这些模块间的依赖关系?Qt Creator的子项目…...

高效突破Steam创意工坊下载限制:WorkshopDL让跨平台玩家轻松获取模组

高效突破Steam创意工坊下载限制:WorkshopDL让跨平台玩家轻松获取模组 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 你是否曾因平台限制而无法下载心仪的Steam创意…...

向量数据库 PGVector、Qdrant 与 Milvus

一、PGVector为什么推荐 PGVector 作为 RAG 的入门首选?理由很直接——你的项目大概率已经在用 PostgreSQL。 直接加一个扩展,不需要引入新的数据库组件,运维成本最低。DBA 会用 PG,就会维护 PGVector。这种“复用已有基础设施”的…...

在多模型项目中利用 Taotoken 实现按需切换与成本优化策略

在多模型项目中利用 Taotoken 实现按需切换与成本优化策略 1. 多模型项目的典型需求与挑战 在实际开发中,许多项目需要同时接入多个大模型以满足不同场景的需求。例如,简单问答任务可能只需要基础模型即可完成,而复杂推理或创意生成则需要更…...

五层DNA架构:构建可复用AI知识框架的元方法论

1. 项目概述:从零构建你的领域知识框架工厂如果你和我一样,每天都要和AI打交道,无论是用Claude、Cursor还是Copilot来处理各种专业任务,那你肯定遇到过这个痛点:每次遇到一个新问题,都得从头开始给AI解释背…...

深入产线:拆解MPS芯片量产测试(FT/QA)流程与那些让你头秃的‘异常’案例分析

芯片量产测试的深度解析:从FT/QA流程到异常诊断实战 半导体行业有句老话:"设计决定上限,测试决定下限。"这句话在MPS这类模拟芯片大厂的生产线上体现得尤为明显。作为PTE(量产测试工程师),我们每…...

SONOFF ZBMINIR2 Zigbee智能开关评测与使用指南

1. SONOFF ZBMINIR2:一款小巧但功能强大的Zigbee智能开关作为一名智能家居爱好者,我最近入手了SONOFF最新推出的ZBMINIR2 Zigbee智能开关。这款产品虽然体积小巧,但功能却相当强大。它不仅是一个智能开关,还能作为Zigbee路由器使用…...

告别Win系统Bug!保姆级教程:在WSL2上从零搭建CUDA 11.8 + PyTorch 2.2深度学习环境(含迁移到D盘避坑指南)

告别Win系统Bug!保姆级教程:在WSL2上从零搭建CUDA 11.8 PyTorch 2.2深度学习环境(含迁移到D盘避坑指南) 如果你是一名深度学习开发者,可能已经受够了Windows系统下各种环境配置的麻烦——驱动冲突、路径错误、C盘空间…...

5G入网第一步之后:手把手拆解UE如何从PDCCH上‘听’到SIB1的调度指令

5G入网第一步之后:手把手拆解UE如何从PDCCH上‘听’到SIB1的调度指令 想象一下,你刚搬进一座巨大的新城市,手机信号栏突然跳出5G标志——这一刻背后,是用户设备(UE)像侦探破案般完成的一场精密协作。当UE通…...

5步掌握Krita AI Diffusion:从零到精通的智能绘画完整指南

5步掌握Krita AI Diffusion:从零到精通的智能绘画完整指南 【免费下载链接】krita-ai-diffusion Streamlined interface for generating images with AI in Krita. Inpaint and outpaint with optional text prompt, no tweaking required. 项目地址: https://git…...

AFDM Turbo接收机:6G通信中的关键技术革新

1. AFDM Turbo接收机:下一代通信系统的关键技术革新在6G通信系统的研发浪潮中,AFDM(Affine Frequency Division Multiplexing)作为一种新型多载波调制技术,正在引起学术界和产业界的广泛关注。而Turbo接收机作为其核心…...

新手开发者从零开始使用Taotoken完成第一个AI应用

新手开发者从零开始使用Taotoken完成第一个AI应用 1. 注册Taotoken并获取API Key 要开始使用Taotoken平台,首先需要注册账号并获取API Key。访问Taotoken官网,点击注册按钮完成账号创建。登录后进入控制台,在"API密钥管理"页面点击…...

Vivado综合指南:手把手教你用Verilog代码“召唤”BRAM,并对比IP核生成方式的优劣

Vivado实战:Verilog代码生成BRAM的工程化决策指南 在FPGA开发中,Block RAM(BRAM)作为关键存储资源,其配置方式直接影响项目效率与性能。面对IP核配置与代码生成两种路径,工程师常陷入选择困境——是拥抱图形…...

变现宝多功能知识付费源码,可对接小程序

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示三、学习资料下载一、详细介绍 thinkphp多功能知识付费源码,变现方式多,多领域素材资源知识变现营销裂变独立版本。 支持:视频、音频、图文、文档、会员、社群、用户发布、创作分成…...

Lumafly:空洞骑士玩家的终极模组管理器,跨平台一键安装告别复杂配置 [特殊字符]

Lumafly:空洞骑士玩家的终极模组管理器,跨平台一键安装告别复杂配置 🚀 【免费下载链接】Lumafly A cross platform mod manager for Hollow Knight written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/lu/Lumafly 你是…...

CefFlashBrowser:让Flash内容在现代浏览器中重生的终极解决方案

CefFlashBrowser:让Flash内容在现代浏览器中重生的终极解决方案 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 还记得那些在4399上玩过的经典Flash小游戏吗?那些充…...

LLM代理中高效工具调用与推理优化实践

1. 项目概述"高效工具调用与推理在LLM代理中的应用"这个主题探讨的是如何让大型语言模型(LLM)更智能地使用外部工具和进行逻辑推理。作为一名长期从事AI应用开发的工程师,我发现这是当前LLM落地实践中最具挑战性也最有价值的领域之一。在实际项目中&#…...

终极指南:如何快速修复洛雪音乐六音音源失效问题

终极指南:如何快速修复洛雪音乐六音音源失效问题 【免费下载链接】New_lxmusic_source 六音音源修复版 项目地址: https://gitcode.com/gh_mirrors/ne/New_lxmusic_source 还在为洛雪音乐1.6.0版本后六音音源失效而烦恼吗?今天我将为你带来完整的…...

AI如何革新电影分镜:ShotVerse框架解析与应用

1. 项目概述:当电影制作遇上AI生成技术去年参与某短片项目时,导演临时提出要补拍三个机位镜头,整个团队不得不重新协调场地、演员和设备。这种经历让我开始思考:如果有个工具能根据剧本自动生成多角度镜头素材,影视创作…...

10分钟掌握城通网盘直连解析:突破限速瓶颈的完整技术方案

10分钟掌握城通网盘直连解析:突破限速瓶颈的完整技术方案 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 城通网盘直连解析器是一款专为技术用户设计的开源工具,通过智能API解析…...