Vue 解决多级动态面包屑导航的问题
作者:筱筱酱 发布时间:2024-05-02 17:11:19
标签:Vue,面包屑,导航
固定路由的面包屑导航
我们在配置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


猜你喜欢
- 1.在pycharm下安装scrapy函数库2.将安装好scrapy函数库下的路径配置到系统path的环境变量中3.打开cmd终端输入:sc
- 在python-numpy使用中,可以用双层 for循环对数组元素进行访问,也可以切片成每一行后进行一维数组的遍历。代码如下:import
- 关于如题这几个概念,大部分人应该比较熟悉,但是我昏了好久,所以写下来加深印象。1. 动态语言又叫动态编程语言,是指程序在运行时可以改变其结构
- 本文研究的主要是Python使用requests及BeautifulSoup构建一个网络爬虫,具体步骤如下。功能说明在Python下面可使用
- 用了一段时间的 typescript 之后,深感中大型项目中 typescript 的必要性,它能够提前在编译期避免许多 bug,如很恶心的
- 如果值没有重复的情况,可以先用array_flip()来交换键和值,然后krsort(),最后再array_flip()交换回来,就可以比较
- 在Python3.6提供f-Strings新的字符串格式化语法。不仅更加可读、简洁,相比其他方式也不易造成错误,而且还更快。看完本文你将学习
- 本文实例讲述了python使用urlparse分析网址中域名的方法。分享给大家供大家参考。具体如下:这里给定网址,通过下面这段python代
- Step 1:在服务器图标上单击右键,选择property,然后选connection,把allow remote connection选上
- 安装pyinstallpip install pyinstaller注意事项除非必要,否则尽量不要直接import module,用from
- p>在“服务”中手动启动,显示于是改从控制台启动:然后简单粗暴的找到...\MySQL Server 5.7\新建data文件夹以上所
- 要想从命令行启动mysqld服务器,你应当启动控制台窗口(或“DOS window”)并输入命令:C
- itchat是一个开源的微信个人号接口,使用python调用微信从未如此简单。开源地址https://github.com/littleco
- 测试字符串:<style>v\:* { BEHAVIOR: url(#default#VML) } o\:* { BEHAVIO
- 前言写过前端Javascript代码的同学肯定不会对console对象感到陌生,在调试的过程中我们经常会用console对象在控制台输出一些
- python 中提供一种用于对函数固定属性的函数(与数学上的偏函数不一样)# 通常会返回10进制int('12345') &
- 英文的文档在这里,详细全面,本文仅为自己的学习笔记,只是试图通过转述加深自己的学习,不详细不全面。由于浏览器之间的差异,所以在JS中监听事件
- python opencv实现目标跟踪python-opencv3.0新增了一些比较有用的 * 算法这里根据官网示例写了一个 * 类程序只能
- 关于Pillow与PILPIL(Python Imaging Library)是Python一个强大方便的图像处理库,名气也比较大。不过只支
- 1. 打开新的窗口并传送参数: 传送参数: response.write("<script>window.o