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 相关文章推荐
jQuery 行背景颜色的交替显示(隔行变色)实现代码
Dec 13 Javascript
js限制文本框输入长度两种限制方式(长度、字节数)
Dec 19 Javascript
javascript判断移动端访问设备并解析对应CSS的方法
Feb 05 Javascript
jQuery通过扩展实现抖动效果的方法
Mar 11 Javascript
JS建造者模式基本用法实例分析
Jun 30 Javascript
JS判断指定dom元素是否在屏幕内的方法实例
Jan 23 Javascript
angularJS之$http:与服务器交互示例
Mar 17 Javascript
详解vuex 中的 state 在组件中如何监听
May 23 Javascript
React + webpack 环境配置的方法步骤
Sep 07 Javascript
详解关于表格合并span-method方法的补充(表格数据由后台动态返回)
May 21 Javascript
react antd实现动态增减表单
Jun 03 Javascript
JavaScript展开运算符和剩余运算符的区别详解
Feb 18 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字符串截取函数用法分析
2014/11/25 PHP
php延迟静态绑定实例分析
2015/02/08 PHP
php HTML无刷新提交表单
2016/04/05 PHP
基于jquery的表头固定的若干方法
2011/01/27 Javascript
深入理解JavaScript系列(11) 执行上下文(Execution Contexts)
2012/01/15 Javascript
jquery 实现表单验证功能代码(简洁)
2012/07/03 Javascript
js文本框走动跑马灯效果代码分享
2015/08/25 Javascript
javascript中Date对象应用之简易日历实现
2016/07/12 Javascript
前端弹出对话框 js实现ajax交互
2016/09/09 Javascript
js中创建对象的几种方式
2017/02/05 Javascript
JS中解决谷歌浏览器记住密码输入框颜色改变功能
2017/02/13 Javascript
解决webpack -p压缩打包react报语法错误的方法
2017/07/03 Javascript
vue 1.0 结合animate.css定义动画效果
2018/07/11 Javascript
15分钟学会vue项目改造成SSR(小白教程)
2019/12/17 Javascript
JavaScript实现图片伪异步上传过程解析
2020/04/10 Javascript
js实现飞机大战小游戏
2020/08/26 Javascript
Python 深入理解yield
2008/09/06 Python
Python 面试中 8 个必考问题
2018/11/16 Python
python实现BP神经网络回归预测模型
2019/08/09 Python
Python3使用PySynth制作音乐的方法
2019/09/09 Python
python 生成器和迭代器的原理解析
2019/10/12 Python
pytorch下大型数据集(大型图片)的导入方式
2020/01/08 Python
TensorFlow学习之分布式的TensorFlow运行环境
2020/02/05 Python
mac安装python3后使用pip和pip3的区别说明
2020/09/01 Python
用HTML5制作数字时钟的教程
2015/05/11 HTML / CSS
String这个类型的class为何定义成final?
2012/11/13 面试题
一份软件工程师的面试试题
2016/02/01 面试题
仓库管理计划书
2014/05/04 职场文书
无毒社区工作方案
2014/05/23 职场文书
学生保证书格式
2015/02/27 职场文书
网聊搭讪开场白
2015/05/28 职场文书
人代会简报
2015/07/21 职场文书
中秋节感想
2015/08/10 职场文书
歌咏比赛口号大全
2015/12/25 职场文书
python 如何获取页面所有a标签下href的值
2021/05/06 Python
「睡美人」爱洛公主粘土人开订
2022/03/22 日漫