vue动态路由实现多级嵌套面包屑的思路与方法
程序员文章站
2022-05-14 19:25:24
前言
最近在工作中遇到了一个问题,是关于vue动态路由多级嵌套面包屑怎么弄(不是动态路由嵌套可以尝试用 this.$route.matched方法获取到path和name...
前言
最近在工作中遇到了一个问题,是关于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}, ] }
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。