Vue 解决多级动态面包屑导航的问题

作者:筱筱酱 时间:2024-05-02 17:11:19 

固定路由的面包屑导航

我们在配置router的时候,可以将面包屑数据配置在meta中,

例如

路由配置:


{
 path: '/project/process/:id',
 name: 'process',
 component: () => import('@/views/project/process/main.vue'),
 meta: [
   { name: '项目管理列表' },
   { name: '项目列表', url: '/project/list' },
   { name: '里程碑' },
 ],
},

代码:


<el-breadcrumb separator-class="el-icon-arrow-right">
<el-breadcrumb-item v-for="(item, index) in $route.meta" :key="index">
   <router-link v-if="item.url" :to="item.url">{{item.name}}</router-link>
   <a v-else>
     {{item.name}}
   </a>
 </el-breadcrumb-item>
</el-breadcrumb>

如果单纯的是展示,就可以不用写url链接,路由配置成这样


{
 path: '/project/process/:id',
 name: 'process',
 component: () => import('@/views/project/process/main.vue'),
 meta: [‘项目管理', '项目进度', '里程碑'],
},

然后代码:


<el-breadcrumb separator="/">
 <el-breadcrumb-item :to="{path: '/home'}">首页</el-breadcrumb-item>
 <el-breadcrumb-item v-for="(item, index) in $route.meta" :key="index">
 {{item}}
 </el-breadcrumb-item>
</el-breadcrumb>

解决Vue多级动态面包屑导航

针对一些比较固定式的面包屑是很好实现的,但是我们在项目中经常会遇到一些动态路由,

例如: A页面路由为 /list

从A页面跳转到B页面为 /list/:id

B页面下又存在一个字页面, /list/detail

我们在C页面想通过面包屑导航的方式进入B页面怎么办呢?

针对这种动态嵌套多级路由应该怎么处理呢?

配置路由


...
{
 path: '/type',
 name: 'type',
 component: () => import('@/views/type/main.vue'),
 meta: [
   { name: '项目分类' },
 ],
},
{
 path: '/type/list/:id',
 name: 'list',
 component: () => import('@/views/list/type/main.vue'),
 meta: [
   { name: '项目分类', url: '/list' },
   { name: '项目列表' },
 ],
},
{
 path: '/list/detail',
 name: 'detail',
 component: () => import('@/views/type/list/detail/index.vue'),
 meta: [
   { name: '项目分类', url: '/list' },
   { name: '项目列表', url: '/type/list' },
   { name: '详情' },
 ],
},
...

可以看出这个路由没有什么区别,唯一值得注意的一点就是里详情页面,是一个动态的路由,从详情页面跳转到项目列表我们需要相应的id信息,但是此时id我们不能固定填入,而是一个动态的值。

修改detail页面

在milestone页面监听beforeRouteEnter事件


beforeRouteEnter(to, from, next) {
 const meta = to.meta;
 for (let i = 0; i < meta.length; i++) {
   if (meta[i].name === '项目列表') {
     meta[i].url = `/type/list/${from.params.id}`;
   }
 }
 next();
 },

在beforeRouteEnter事件中修改meta信息,从而更新面包屑的导航路由。

主要的实现思路就是在目标页面添加beforeRouteEnter事件,然后更改其meta配置信息,从而达到更改面包屑导航路径。

如果你还有更好的解决办法,欢迎留言。

来源:https://juejin.im/post/5cfe235df265da1b8d1611b3

标签:Vue,面包屑,导航
0
投稿

猜你喜欢

  • 获取 Textarea 的光标位置

    2010-11-30 21:33:00
  • 读"设计的3个C"之构图

    2008-12-24 13:25:00
  • asp javascript值的互相传递方法

    2011-03-30 10:37:00
  • Python打印不合法的文件名

    2021-06-29 03:40:19
  • Python抓新型冠状病毒肺炎疫情数据并绘制全国疫情分布的代码实例

    2022-10-11 23:14:40
  • mysql的存储过程、游标 、事务实例详解

    2024-01-12 22:02:15
  • PHP面向对象程序设计继承用法简单示例

    2023-11-22 08:09:42
  • Mysql查询语句优化技巧

    2024-01-19 15:41:08
  • SQLServer Execpt和not in 性能区别

    2024-01-21 23:33:46
  • 探讨链接打开方式

    2009-03-16 16:55:00
  • vue 计时器组件的实现代码

    2023-07-02 16:59:56
  • 如何将pytorch模型部署到安卓上的方法示例

    2023-03-15 15:12:12
  • asp开发Wap中的随笔

    2008-05-21 12:56:00
  • vscode配置与python虚拟环境切换的几种方式总结

    2023-09-04 07:09:28
  • 手把手教你搭建一个vue项目的完整步骤

    2023-07-02 17:05:48
  • 仿天涯底部固定漂浮导航,无JS纯CSS定义

    2009-07-06 12:44:00
  • 详解PHP实现HTTP服务器过程

    2023-05-26 20:17:12
  • Python利用fitz库提取pdf中的图片

    2021-10-06 20:12:14
  • Python实现简单拆分PDF文件的方法

    2022-09-27 19:20:37
  • js 点击a标签 获取a的自定义属性方法

    2024-04-16 10:33:02
  • asp之家 网络编程 m.aspxhome.com