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 相关文章推荐
javascript与webservice的通信实现代码
Dec 25 Javascript
屏蔽script注入小例子
Nov 12 Javascript
深入领悟JavaScript中的面向对象
Nov 18 Javascript
JS折半插入排序算法实例
Dec 02 Javascript
js获取url传值的方法
Dec 18 Javascript
js实现prototype扩展的方法(字符串,日期,数组扩展)
Jan 14 Javascript
详解前端路由实现与react-router使用姿势
Aug 07 Javascript
node前端模板引擎Jade之标签的基本写法
May 11 Javascript
Intellij IDEA搭建vue-cli项目的方法步骤
Oct 20 Javascript
vue+Vue Router多级侧导航切换路由(页面)的实现代码
Dec 20 Javascript
VUE项目初建和常见问题总结
Sep 12 Javascript
Vue组件简易模拟实现购物车
Dec 21 Vue.js
基于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求最大子序列和的算法实现
2011/06/24 PHP
php教程 插件机制在PHP中实现方案
2012/11/02 PHP
从js向Action传中文参数出现乱码问题的解决方法
2013/12/29 Javascript
js showModalDialog参数的使用详解
2014/01/07 Javascript
3个可以改善用户体验的AngularJS指令介绍
2015/06/18 Javascript
js实现Select列表内容自动滚动效果代码
2015/08/20 Javascript
jQuery实现的超简单点赞效果实例分析
2015/12/31 Javascript
信息页文内画中画广告js实现代码(文中加载广告方式)
2016/01/03 Javascript
JavaScript实现换肤功能
2017/09/15 Javascript
jQuery实现可兼容IE6的遮罩功能详解
2017/09/19 jQuery
vue+node+webpack环境搭建教程
2017/11/05 Javascript
使用JS获取SessionStorage的值
2018/01/12 Javascript
使用Vue.js开发微信小程序开源框架mpvue解析
2018/03/20 Javascript
关于vue v-for 循环问题(一行显示四个,每一行的最右边那个计算属性)
2018/09/04 Javascript
jQuery 操作 HTML 元素和属性的方法
2018/11/12 jQuery
详解JavaScript 高阶函数
2020/09/14 Javascript
[04:50]2019DOTA2高校联赛秋季赛四强集锦
2019/12/27 DOTA
tensorflow构建BP神经网络的方法
2018/03/12 Python
Python3.5文件读与写操作经典实例详解
2019/05/01 Python
Django 项目通过加载不同env文件来区分不同环境
2020/02/17 Python
python将下载到本地m3u8视频合成MP4的代码详解
2020/11/24 Python
python使用scapy模块实现ping扫描的过程详解
2021/01/21 Python
就业推荐表自我鉴定
2013/10/29 职场文书
参观监狱心得体会
2014/01/02 职场文书
个人自我评价和职业目标
2014/01/24 职场文书
德语专业求职信
2014/03/12 职场文书
工伤事故赔偿协议书
2014/04/15 职场文书
挂靠协议书范本
2014/04/22 职场文书
仓库规划计划书
2014/04/28 职场文书
运动会开幕词
2015/01/28 职场文书
圣诞节开幕词
2015/01/29 职场文书
学校实习推荐信
2015/03/27 职场文书
入党培养人考察意见
2015/06/08 职场文书
大学生,三分钟即兴演讲稿
2019/07/22 职场文书
Java实现简易的分词器功能
2021/06/15 Java/Android
spring cloud gateway中如何读取请求参数
2021/07/15 Java/Android