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


Posted in Javascript onNovember 04, 2019

固定路由的面包屑导航

我们在配置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配置信息,从而达到更改面包屑导航路径。

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

以上这篇Vue 解决多级动态面包屑导航的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
轻轻松松学习JavaScript
Feb 25 Javascript
js判断设备是否为PC并调整图片大小
Feb 12 Javascript
JS使用getComputedStyle()方法获取CSS属性值
Apr 23 Javascript
javascript匿名函数实例分析
Nov 18 Javascript
如何实现移动端浏览器不显示 pc 端的广告
Oct 15 Javascript
jQuery插件之jQuery.Form.js用法实例分析(附demo示例源码)
Jan 04 Javascript
Js+Ajax,Get和Post在使用上的区别小结
Jun 08 Javascript
JavaScript中实现键值对应的字典与哈希表结构的示例
Jun 12 Javascript
js文件中直接alert()中文出来的是乱码的解决方法
Nov 01 Javascript
js事件源window.event.srcElement兼容性写法(详解)
Nov 25 Javascript
js 获取今天以及过去日期
Apr 11 Javascript
利用Vconsole和Fillder进行移动端抓包调试方法
Mar 05 Javascript
vue+elementUI动态生成面包屑导航教程
Nov 04 #Javascript
VUE+elementui面包屑实现动态路由详解
Nov 04 #Javascript
Vuex,iView UI面包屑导航使用扩展详解
Nov 04 #Javascript
vue双向绑定数据限制长度的方法
Nov 04 #Javascript
使用p5.js临摹动态图片
Nov 04 #Javascript
p5.js绘制创意自画像
Nov 04 #Javascript
Vue图片浏览组件v-viewer用法分析【支持旋转、缩放、翻转等操作】
Nov 04 #Javascript
You might like
调整PHP的性能
2013/10/30 PHP
php实现httpclient类示例
2014/04/08 PHP
浅析PHP7新功能及语法变化总结
2016/06/17 PHP
php中简单的对称加密算法实现
2017/01/05 PHP
Yii2实现多域名跨域同步登录退出
2017/02/04 PHP
PHP设计模式之原型模式定义与用法详解
2018/04/03 PHP
PHP时间类完整代码实例
2021/02/26 PHP
JavaScript入门教程(10) 认识其他对象
2009/01/31 Javascript
jQuery对象和DOM对象相互转化
2009/04/24 Javascript
基于jquery的textarea发布框限制文字字数输入(添加中文识别)
2012/02/16 Javascript
JS简单实现元素复制示例附图
2013/11/19 Javascript
超精准的javascript验证身份证号的具体实现方法
2015/11/18 Javascript
微信小程序开发之Tabbar实例详解
2017/01/09 Javascript
使用jQuery,Angular实现登录界面验证码详解
2017/04/27 jQuery
纯js实现隔行变色效果
2017/11/29 Javascript
JavaScript重复元素处理方法分析【统计个数、计算、去重复等】
2017/12/14 Javascript
一篇超完整的Vue新手入门指导教程
2020/11/18 Vue.js
[52:08]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第一局
2016/03/05 DOTA
详解flask表单提交的两种方式
2018/07/21 Python
python使用adbapi实现MySQL数据库的异步存储
2019/03/19 Python
python实现扫描ip地址的小程序
2019/04/16 Python
将tensorflow.Variable中的某些元素取出组成一个新的矩阵示例
2020/01/04 Python
Pandas —— resample()重采样和asfreq()频度转换方式
2020/02/26 Python
jupyter 添加不同内核的操作
2021/02/06 Python
泰国健康和美容服务预订网站:GoWabi
2019/06/03 全球购物
素食餐饮项目创业计划书
2014/02/02 职场文书
高一数学教学反思
2014/02/07 职场文书
教学质量评估实施方案
2014/03/17 职场文书
2014年纠风工作总结
2014/12/08 职场文书
2015秋季开学典礼新闻稿
2015/07/17 职场文书
七一表彰大会简报
2015/07/20 职场文书
2016中秋晚会开幕词
2016/03/03 职场文书
Nginx+Tomcat实现负载均衡、动静分离的原理解析
2021/03/31 Servers
MySQL创建管理子分区
2022/04/13 MySQL
分析SQL窗口函数之排名窗口函数
2022/04/21 Oracle
JS实现九宫格拼图游戏
2022/06/28 Javascript