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 相关文章推荐
js 模拟实现类似c#下的hashtable的简单功能代码
Jan 24 Javascript
JavaScript使用Math.Min返回两个数中较小数的方法
Apr 06 Javascript
Javascript实现div的toggle效果实例分析
Jun 09 Javascript
JavaScript+CSS实现仿Mootools竖排弹性动画菜单效果
Oct 14 Javascript
jquery单击事件和双击事件冲突解决方案
Mar 02 Javascript
js HTML5多图片上传及预览实例解析(不含前端的文件分割)
Aug 26 Javascript
jQuery源码分析之sizzle选择器详解
Feb 13 Javascript
webpack学习--webpack经典7分钟入门教程
Jun 28 Javascript
js+html5生成自动排列对话框实例
Oct 09 Javascript
解决bootstrap中下拉菜单点击后不关闭的问题
Aug 10 Javascript
你可能从未使用过的11+个JavaScript特性(小结)
Jan 08 Javascript
vue 解决data中定义图片相对路径页面不显示的问题
Aug 13 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&amp;&amp;mysql)五
2006/10/09 PHP
强烈声明: 不要使用(include/require)_once
2013/06/06 PHP
PHP扩展模块memcached长连接使用方法分析
2014/12/24 PHP
使用 PHPStorm 开发 Laravel
2015/03/24 PHP
Codeigniter控制器controller继承问题实例分析
2016/01/19 PHP
php实现批量删除挂马文件及批量替换页面内容完整实例
2016/07/08 PHP
php接口隔离原则实例分析
2019/11/11 PHP
Javascript与vbscript数据共享
2007/01/09 Javascript
Prototype使用指南之form.js
2007/01/10 Javascript
Jquery网页内滑动缓冲导航的实现代码
2015/04/05 Javascript
jQuery+html5实现div弹出层并遮罩背景
2015/04/15 Javascript
Jquery插件easyUi实现表单验证示例
2015/12/15 Javascript
jQuery mobile在页面加载时添加加载中效果 document.ready 和window.onload执行顺序比较
2016/07/14 Javascript
基于jQuery实现多标签页切换的效果(web前端开发)
2016/07/24 Javascript
js排序与重组的实例讲解
2017/08/28 Javascript
vue 路由页面之间实现用手指进行滑动的方法
2018/02/23 Javascript
vue 多入口文件搭建 vue多页面搭建的实例讲解
2018/03/12 Javascript
nodejs更改项目端口号的方法
2018/05/13 NodeJs
解决在Vue中使用axios用form表单出现的问题
2019/10/30 Javascript
详解javascript中var与ES6规范中let、const区别与用法
2020/01/11 Javascript
Python字符编码与函数的基本使用方法
2017/09/30 Python
Python实现注册、登录小程序功能
2018/09/21 Python
python获取时间及时间格式转换问题实例代码详解
2018/12/06 Python
python区分不同数据类型的方法
2019/10/14 Python
HTML5的结构和语义(1):前言
2008/10/17 HTML / CSS
HTML5+CSS3实现机器猫
2016/10/17 HTML / CSS
现金会计岗位职责
2013/12/05 职场文书
自我评价范文
2013/12/22 职场文书
幼儿园义卖活动方案
2014/01/17 职场文书
承诺书怎么写
2014/03/26 职场文书
秋天的怀念教学反思
2014/04/28 职场文书
2014党支部对照检查材料思想汇报
2014/10/05 职场文书
怀孕辞职信怎么写
2015/02/28 职场文书
会议通知格式范文
2015/04/15 职场文书
2015年财政所工作总结
2015/04/25 职场文书
导游词之任弼时故居
2020/01/07 职场文书