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中jquery.form中ajax提交没反应解决方法分享
Sep 11 Javascript
jQuery获取和设置表单元素的方法
Feb 14 Javascript
jQuery Validate 验证,校验规则写在控件中的具体实例
Feb 27 Javascript
html5+javascript制作简易画板附图
Apr 25 Javascript
js实现点击按钮后给Div图层设置随机背景颜色的方法
May 06 Javascript
JavaScript学习小结(一)——JavaScript入门基础
Sep 02 Javascript
js动态生成Html元素实现Post操作(createElement)
Sep 14 Javascript
jquery动态添加文本并获取值的方法
Oct 12 Javascript
Vue表单类的父子组件数据传递示例
May 03 Javascript
Vue的v-model的几种修饰符.lazy,.number和.trim的用法说明
Aug 05 Javascript
vue中利用mqtt服务端实现即时通讯的步骤记录
Jul 01 Vue.js
关于Vue中的options选项
Mar 22 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中的正则表达式以及模式匹配
2013/06/19 PHP
使用PHP生成PDF方法详解
2015/01/23 PHP
详解Window7 下开发php扩展
2015/12/31 PHP
php下载文件,添加响应头的简单实例
2016/09/22 PHP
PHP7匿名类的用法示例
2019/04/05 PHP
Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示例
2019/10/12 PHP
复制本贴标题和地址的js代码
2008/07/01 Javascript
JavaScript中String和StringBuffer的速度之争
2010/04/01 Javascript
jQuery UI AutoComplete 自动完成使用小记
2010/08/21 Javascript
Fixie.js 自动填充内容的插件
2012/06/28 Javascript
js控制表单奇偶行样式的简单方法
2013/07/31 Javascript
javascript的replace方法结合正则使用实例总结
2016/06/16 Javascript
移动端js触摸事件详解
2016/09/18 Javascript
微信端开发--登录小程序步骤
2017/01/11 Javascript
js中document.referrer实现移动端返回上一页
2017/02/22 Javascript
JavaScript中闭包的详解
2017/04/01 Javascript
webpack下实现动态引入文件方法
2018/02/22 Javascript
ES6使用 Array.includes 处理多重条件用法实例分析
2020/03/02 Javascript
js实现带箭头的进度流程
2020/03/26 Javascript
如何管理Vue中的缓存页面
2021/02/06 Vue.js
[05:31]DOTA2上海特级锦标赛主赛事第三日RECAP
2016/03/05 DOTA
Django实战之用户认证(用户登录与注销)
2018/07/16 Python
python-itchat 获取微信群用户信息的实例
2019/02/21 Python
python使用wxpy轻松实现微信防撤回的方法
2019/02/21 Python
django实现用户注册实例讲解
2019/10/30 Python
使用Python FastAPI构建Web服务的实现
2020/06/08 Python
获取python运行输出的数据并解析存为dataFrame实例
2020/07/07 Python
详解selenium + chromedriver 被反爬的解决方法
2020/10/28 Python
为什么说Ruby是一种真正的面向对象程序设计语言
2012/10/30 面试题
安全资金保障制度
2014/01/23 职场文书
省优秀教师事迹材料
2014/01/30 职场文书
2015财务年度工作总结范文
2015/05/04 职场文书
2015年初一班主任工作总结
2015/05/13 职场文书
2016党员学习作风建设心得体会
2016/01/21 职场文书
技术转让协议书
2016/03/19 职场文书
Python OpenCV实现图像模板匹配详解
2022/04/07 Python