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

网友投稿 589 2023-04-19


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

前言

最近在工作中遇到了一个问题,是关于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:'三级'}] ,然后遍历出来如: {{item.name}}

做法

下面贴出相关代码:

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

B列表页面跳转按钮:

breadcrumb.vue页面:

{{item.name}}

状态管理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},

]

}

总结

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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:vue实现留言板todolist功能
下一篇:React应用中使用Bootstrap的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~