vue动态路由实现多级嵌套面包屑的思路与方法


Posted in Javascript onAugust 16, 2017

前言

最近在工作中遇到了一个问题,是关于vue动态路由多级嵌套面包屑怎么弄(不是动态路由嵌套可以尝试用 this.$route.matched方法获取到path和name集合,动态的嵌套获取不到全部具体的id)

功能比如:A列表页面路由如/a,点击任意一列进入任意一个A的详情页面名字为B,/b/03(这个是动态路由弄是吧,03就是id嘛),点击B页面任意一列,再进入B的详情页名字为C,路由如/bdetail/01;现在弄面包屑要获取到的路由是刚刚打开的,如(/a;/b/03;/bdetail/01)

思路:获取所有进入的层级的路由和名称如breadlist=[{path:'/a',name:'一级'},{path:'/b/03',name:'二级'},{path:'/bdetail/01',name:'三级'}] ,然后遍历出来如: <span v-for="(item in breadlist)"><router-link :to="item.path">{{item.name}}</router-link></span>

做法

下面贴出相关代码:

A列表页面跳转按钮:(breadNum记录面包屑层级)

<router-link :to="{path:'/b/'+id,query:{breadNum:2}}"></router-link>

B列表页面跳转按钮:

<router-link :to="{path:'/bbdetail/'+id,query:{breadNum:3}}"></router-link>

breadcrumb.vue页面:

<template>
  <div class="breadbox">
   <span v-for="(item,index) in breadlist" >
    <router-link :to="item.path">{{item.name}}</router-link>
   </span>
  </div>
</template>
<script>
 export default{
  created() {
   this.getBreadcrumb();
  },
  data() {
   return {
    breadlist: '' // 路由集合
   }
  },
  methods: {
   getBreadcrumb() {
    var breadNumber= this.$route.query.breadNum || 1;//url变量breadNum记录层级,默认为1,如果大于1,要添加上变量;
    var breadLength=this.$store.state.breadListState.length;//目前breadlist集合数组个数
    var curName=this.$route.name;
    var curPath=this.$route.fullPath;
    var newBread={name:curName,path:curPath};
    var ishome=curName=='首页';
    console.log(ishome);
    if(breadNumber===1){//点击一级菜单
     this.$store.commit('breadListStateRemove',1);//初始化,只有首页面包屑按钮
     if(!ishome)//如果不是首页
      this.$store.commit('breadListStateAdd',newBread);//当前页面添加到breadlist集合
    }
    else if(breadLength<=breadNumber){//如果不是一级导航,并且breadlist集合个数等于或者小于目前层级
     this.$store.commit('breadListStateAdd',newBread);//要把当前路由添加到breadlist集合
    }else{
     this.$store.commit('breadListStateRemove',parseInt(breadNumber)+1);//如果往回点面包屑导航,截取;
    }
    this.breadlist=this.$store.state.breadListState;
    console.log(this.breadlist);
   }
  },
  watch: {
   $route () {
    this.getBreadcrumb();
   }
  },
 }
</script>

状态管理store.js代码:

export default store = new Vuex.Store({
 state: {
 breadListState:[
  {name:'首页',path:'/'}
 ]
 },
 mutations: {
 breadListStateAdd(state,obj){
  state.breadListState.push(obj);
 },
 breadListStateRemove(state,num){
  state.breadListState=state.breadListState.slice(0,num);
 }
 }

})

路由route.js代码:

{
 path: '/',
 name: '首页',
 component: Main,
 redirect:'/home',
 children:[
  {path: '/a',name: 'A页面',component: APage},
  {path: '/b/:id',name: 'B页面',component: BPage},
  {path: '/bdetail/:id',name: 'C页面',component: CPage},
 ]
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
IE和firefox浏览器的event事件兼容性汇总
Dec 06 Javascript
js更优雅的兼容
Aug 12 Javascript
基于jquery的图片的切换(以数字的形式)
Feb 14 Javascript
Javascript进制转换实例分析
May 14 Javascript
JS开发中百度地图+城市联动实现实时触发查询地址功能
Apr 13 Javascript
JS实现评价的星星功能
Aug 20 Javascript
详解基于vue-router的动态权限控制实现方案
Sep 28 Javascript
layui实现table加载的示例代码
Aug 14 Javascript
JavaScript面向对象编程小游戏---贪吃蛇代码实例
May 15 Javascript
Vue项目中ESlint规范示例代码
Jul 04 Javascript
es6函数name属性功能与用法实例分析
Apr 18 Javascript
利用promise及参数解构封装ajax请求的方法
Mar 24 Javascript
基于js 本地存储(详解)
Aug 16 #Javascript
基于Vue实例生命周期(全面解析)
Aug 16 #Javascript
基于JQuery的Ajax方法使用详解
Aug 16 #jQuery
angular或者js怎么确定选中ul中的哪几个li
Aug 16 #Javascript
JS操作时间 - UNIX时间戳的简单介绍(必看篇)
Aug 16 #Javascript
label+input实现按钮开关切换效果的实例
Aug 16 #Javascript
bootstrap modal+gridview实现弹出框效果
Aug 15 #Javascript
You might like
php模块memcache和memcached区别分析
2011/06/14 PHP
windows下的WAMP环境搭建图文教程(推荐)
2017/07/27 PHP
ThinkPHP实现的rsa非对称加密类示例
2018/05/29 PHP
thinkphp整合系列之极验滑动验证码geetest功能
2019/06/18 PHP
JavaScript基本对象
2007/01/11 Javascript
网页中可关闭的漂浮窗口实现可自行调节
2013/08/20 Javascript
jquery让指定的元素闪烁显示的方法
2015/03/17 Javascript
JavaScript弹出新窗口后向父窗口输出内容的方法
2015/04/06 Javascript
详谈LABJS按需动态加载js文件
2015/05/07 Javascript
Javascript通过overflow控制列表闭合与展开的方法
2015/05/15 Javascript
基于Jquery实现仿百度百科右侧导航代码附源码下载
2015/11/27 Javascript
JavaScript如何实现在文本框(密码框)输入提示语
2015/12/25 Javascript
AngularJS入门教程之表单校验用法示例
2016/11/02 Javascript
php输出全部gb2312编码内的汉字方法
2017/03/04 Javascript
解决vue 项目引入字体图标报错、不显示等问题
2018/09/01 Javascript
node版本管理工具n包使用教程详解
2018/11/09 Javascript
Python编程中运用闭包时所需要注意的一些地方
2015/05/02 Python
使用Python对SQLite数据库操作
2017/04/06 Python
Python 虚拟空间的使用代码详解
2019/06/10 Python
Python数据分析模块pandas用法详解
2019/09/04 Python
pandas中遍历dataframe的每一个元素的实现
2019/10/23 Python
Python实现像awk一样分割字符串
2020/09/15 Python
Html5实现用户注册自动校验功能实例代码
2016/05/24 HTML / CSS
比较基础的php面试题及答案-填空题
2014/04/26 面试题
SQL面试题
2013/12/09 面试题
什么是测试驱动开发(TDD)
2012/02/15 面试题
生产主管岗位职责
2013/11/10 职场文书
刘胡兰的英雄事迹材料
2014/02/11 职场文书
小学生感恩父母演讲稿
2014/08/28 职场文书
音乐教育专业自荐信
2014/09/18 职场文书
护士长2014年终工作总结
2014/11/11 职场文书
《圆明园的毁灭》教学反思
2016/02/16 职场文书
8g内存用python读取10文件_面试题-python 如何读取一个大于 10G 的txt文件?
2021/05/28 Python
PostgreSQL并行计算算法及参数强制并行度设置方法
2022/04/06 PostgreSQL
MySQL数据库中的锁、解锁以及删除事务
2022/05/06 MySQL
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript