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

动态组件驱动的标签页架构(简单来说:一个页面包含许多Tabs页面,这些Tabs页面渲染逻辑)

整体渲染思路:

1. TabMenu创建 → 解析路由配置 → 生成tabPanes数据
2. TabPanes接收数据 → 遍历创建el-tab-pane
3. 用户点击标签 → activeName改变
4. Vue发现activeName匹配 → 调用对应的componentName函数
5. loadView执行 → require()加载组件文件
6. 组件加载完成 → 渲染到页面
7. keep-alive缓存 → 切换时保持状态

// TabMenu.vue <template> <div> <TabPanes :key="$route.path" :tabPanes.sync="tabPanes" /> </div> </template> <script> import TabPanes from "@/components/TabPane/tab-pane"; function loadView(view) { return resolve => require([`@/views/${view}`], resolve); } export default { components: { TabPanes }, data() { return { tabPanes: null }; }, created() { this.init(); }, methods: { init() { const tabs = this.$route.meta.tabs; this.tabPanes = tabs.map(item => { return { title: item.name, name: item.code, componentName: loadView([item.component]) }; }); } }, watch: { "$route.path": function(newVal, oldVal) { this.init(); } } }; </script>
// tab-pane.vue <template> <el-tabs v-model="activeName" :type="tabType" @tab-click="tabClick" class="tab-panes" > <template> <el-tab-pane v-for="(tab, index) in tabPanes" :key="tab.title+index" :label="tab.title" :lazy="true" :name="tab.name" > <keep-alive> <component class="content" v-if="activeName === tab.name" :is="tab.componentName" /> </keep-alive> </el-tab-pane> </template> </el-tabs> </template> <script> //这是tabPane要显示的组件 export default { name: "TabPanes", props: { tabPanes: { type: Array, default: () => [] }, tabType: { type: String, default: "" } }, data() { return { activeName: null }; }, created() { this.setActiveTab(); }, mounted(){ this.setActiveTab(); }, watch: { activeName: { handler(val) { if (val) { this.$router.replace({ query: { tab: val }, params: { ...this.$route.params } }); } }, }, "$route.query.tab"(val) { this.activeName = val || ''; }, tabPanes: { handler(val) { if (val.length > 0 && !this.$route.query.tab) { this.activeName = val[0].name; } } }, }, methods: { setActiveTab() { const tabFromQuery = this.$route.query.tab; const isValidTab = tabFromQuery && this.tabPanes.some(tab => tab.name === tabFromQuery); this.activeName = isValidTab ? tabFromQuery : (this.tabPanes[0] && this.tabPanes[0].name || ''); }, tabClick(tab) { this.activeName = tab.name; }, } }; </script> <style lang="scss" scoped> .el-tabs { position: absolute; inset: 0; overflow: overlay; & ::v-deep .el-tabs__header { padding: 0; position: relative; margin: 0 0 0 10px; border-top: 1px solid #bfcbd9; } & ::v-deep .el-tabs__nav-wrap { background-color: #fff !important; padding-left: 10px; } &::-webkit-scrollbar { width: 10px; background: transparent; } &::-webkit-scrollbar-thumb { border-radius: 9px; background-color: #c0c0c0; } } </style>

TabMenu.vue 是在哪里被调用的?
结论:TabMenu.vue 不是在前端代码中直接调用的,而是通过后端返回的动态路由配置来加载的!


整个过程是:
1.用户访问某个URL(比如 /xxx )
2.权限系统检查用户是否有该页面权限
3.后端返回菜单配置,其中包含:

{
"path": "/xxx",
"component": "component/TabMenu",
"meta": {
"tabs": [
{"code": "xxx", "name": "tab页面名称", "component": "xx/xx/xx"}
]
}
}

4.前端动态加载 component/TabMenu.vue 组件
5.TabMenu执行,解析 meta.tabs 配置,渲染子页面

这就是为什么你找不到直接调用的原因!
TabMenu是动态路由系统的一部分,由后端菜单配置驱动,而不是在前端代码中硬编码引用的。

这种设计的优势:
权限灵活:可以动态控制谁可以访问哪些页面
菜单可配置:管理员可以配置页面结构,无需修改前端代码
组件按需加载:只在需要时才加载对应的Vue组件

http://www.cnnetsun.cn/news/15152.html

相关文章:

  • 24小时挑战:用AI快速打造‘旺仔‘风格IP原型
  • 零基础搞定Umi项目自动化部署:从代码到上线的完整指南
  • 数学分析简明教程——6.2
  • SSM物业缴费管理系统u8mx4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
  • 如何在PowerPoint中轻松插入LaTeX公式:终极解决方案
  • Ultralytics YOLOv11终极性能优化:从配置到实战的完整指南
  • 突破传统:3大实战方法让GLM语言模型成为你的AI生产力工具
  • 3步快速解决HeyGem.ai性能问题:终极优化指南
  • 自助项目全解析:适配老板画像业态选择指南
  • 传统链表OUT了!侵入式链表让Nginx、TCMalloc 性能飞跃的秘密武器
  • MinIO效率革命:传统存储方案对比实测
  • AI如何帮你彻底理解box-sizing的奥秘
  • 如何用AI自动生成OpenRGB灯光控制脚本
  • 告别深夜改Bug!CodeGenie帮你快速“驯服”鸿蒙编译错误!
  • 企业IT运维:批量处理设备启动故障(代码10)实战
  • 3天掌握VAR模型:零基础搭建GPT式图像生成系统
  • Headless Recorder完整指南:从零掌握浏览器自动化脚本生成
  • 终极指南:如何用ConvNeXt实现高效语义分割(UperNet完整教程)
  • 包装设计创意大比拼,谁才是行业王者?
  • 项目分享|Tabby:打造你自己的智能代码补全服务
  • 终极音频解锁指南:3分钟掌握浏览器端音乐格式转换
  • Word中批量给手机号打码,分享2种高效加密方法!
  • 5大核心优势解析:为什么Screenbox成为Windows平台最佳免费播放器
  • 【必学收藏】RAG技术详解:解决大模型幻觉的终极指南,从入门到实战
  • 有序数组的平方——双指针
  • DBeaver数据库对象搜索失效的5分钟紧急修复指南
  • PHP 15 个高效开发的小技巧
  • 三级防护+119种语言:Qwen3Guard-Gen重新定义2025大模型安全标准
  • Brotli解压引擎深度解密:从位流到字节的魔法转换
  • 深度解析 MySQL 与 MCP 集成:从环境构建到 AI 驱动的数据交互全流程