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 相关文章推荐
捕获键盘事件(且兼容各浏览器)
Jul 03 Javascript
一个支付页面DEMO附截图
Jul 22 Javascript
JavaScript匿名函数与委托使用示例
Jul 22 Javascript
20个实用的JavaScript技巧分享
Nov 28 Javascript
js中的内部属性与delete操作符介绍
Aug 10 Javascript
JS+CSS简单树形菜单实现方法
Sep 12 Javascript
有关easyui-layout中的收缩层无法显示标题的解决办法
May 10 Javascript
jQuery选择器特殊字符与属性空格问题
Aug 14 jQuery
JavaScript中BOM对象原理与用法分析
Jul 09 Javascript
解决微信小程序中的滚动穿透问题
Sep 16 Javascript
el-table表头根据内容自适应完美解决表头错位和固定列错位
Jan 07 Javascript
详解node.js创建一个web服务器(Server)的详细步骤
Jan 15 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
收音机玩机评测 406 篇视频合集
2020/03/11 无线电
ThinkPHP实现一键清除缓存方法
2014/06/26 PHP
phpMyAdmin安装并配置允许空密码登录
2015/07/04 PHP
php如何连接sql server
2015/10/16 PHP
thinkPHP3.1验证码的简单实现方法
2016/04/22 PHP
微信接口生成带参数的二维码
2017/07/31 PHP
浅析PHP类的反射来实现依赖注入过程
2018/02/06 PHP
用js怎么把&amp;字符换成&quot;&amp;amp:&quot;
2006/10/19 Javascript
JSON中双引号的轮回使用过程中一定要小心
2014/03/05 Javascript
ExtJS4如何自动生成控制grid的列显示、隐藏的checkbox
2014/05/02 Javascript
JavaScript利用正则表达式去除日期中的-
2014/06/09 Javascript
jQuery和AngularJS的区别浅析
2015/01/29 Javascript
Node.js中child_process实现多进程
2015/02/03 Javascript
简介JavaScript中Math.LOG10E属性的使用
2015/06/14 Javascript
jQuery实现form表单基于ajax无刷新提交方法详解
2015/12/08 Javascript
jquery 标签 隔若干行加空白或者加虚线的方法
2016/12/07 Javascript
关于定制FileField中的上传文件名称问题
2017/08/22 Javascript
AngularJS使用ng-repeat遍历二维数组元素的方法详解
2017/11/11 Javascript
详解vue通过NGINX部署在子目录或者二级目录实践
2018/09/03 Javascript
JavaScript实现鼠标经过表格某行时此行变色
2020/11/20 Javascript
Python中的MongoDB基本操作:连接、查询实例
2015/02/13 Python
在Heroku云平台上部署Python的Django框架的教程
2015/04/20 Python
Python实现的IP端口扫描工具类示例
2019/02/15 Python
python列表每个元素同增同减和列表元素去空格的实例
2019/07/20 Python
Linux下通过python获取本机ip方法示例
2019/09/06 Python
django实现web接口 python3模拟Post请求方式
2019/11/19 Python
python读取ini配置文件过程示范
2019/12/23 Python
解决Tensorboard可视化错误:不显示数据 No scalar data was found
2020/02/15 Python
Selenium基于PIL实现拼接滚动截图
2020/04/10 Python
解决tensorflow读取本地MNITS_data失败的原因
2020/06/22 Python
HTML5 对各个标签的定义与规定:body的介绍
2012/06/21 HTML / CSS
岳庙导游词
2015/02/04 职场文书
宝宝满月祝酒词
2015/08/10 职场文书
2015元旦感言
2015/12/09 职场文书
深入理解Pytorch微调torchvision模型
2021/11/11 Python
HDFS免重启挂载新磁盘
2022/04/06 Servers