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:'三级'}] ,然后遍历出来如:

做法

下面贴出相关代码

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

rush:xhtml;">

B列表页跳转按钮:

rush:xhtml;">

breadcrumb.vue页面

rush:xhtml;">

状态管理store.js代码

rush: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代码

rush: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},] }

总结

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

相关文章

可以通过min-width属性来设置el-table-column的最小宽度。以...
yarn dev,当文件变动后,会自动重启。 yanr start不会自动重...
ref 用于创建一个对值的响应式引用。这个值可以是原始值(如...
通过修改 getWK005 函数来实现这一点。这里的 query 参数就是...
<el-form-item label="入库类型" ...
API 变动 样式类名变化: 一些组件的样式类名有所变动,可能需...