前言

最近在工作中遇到了一个问题,是关于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},
]
}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# vue
# 多级路由嵌套
# router
# 面包屑
# vuejs路由实现面包屑
# vue实现动态路由详细
# 详解vue路由篇(动态路由、路由嵌套)
# vue系列之动态路由详解【原创】
# vue 实现动态路由的方法
# Vue动态路由缓存不相互影响的解决办法
# 手把手教你vue实现动态路由
# 首页
# 如果不是
# 跳转
# 遍历
# 要把
# 一个问题
# 这篇文章
# 谢谢大家
# 贴出
# 在工作中
# 怎么弄
# 默认为
# 详情页
# 有疑问
# pre
# link
# breadNum
# div
相关文章:
佛山企业网站制作公司有哪些,沟通100网上服务官网?
电脑免费海报制作网站推荐,招聘海报哪个网站多?
如何破解联通资金短缺导致的基站建设难题?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
北京制作网站的公司,北京铁路集团官方网站?
小型网站制作HTML,*游戏网站怎么搭建?
建站主机选虚拟主机还是云服务器更好?
如何高效配置香港服务器实现快速建站?
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
如何在自有机房高效搭建专业网站?
,怎么在广州志愿者网站注册?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
C#如何序列化对象为XML XmlSerializer用法
如何在万网自助建站平台快速创建网站?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
如何安全更换建站之星模板并保留数据?
黑客如何利用漏洞与弱口令入侵网站服务器?
如何在Tomcat中配置并部署网站项目?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
如何通过虚拟机搭建网站?详细步骤解析
山东网站制作公司有哪些,山东大源集团官网?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
如何在七牛云存储上搭建网站并设置自定义域名?
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
建站主机无法访问?如何排查域名与服务器问题
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
电商网站制作公司有哪些,1688网是什么意思?
建站之星如何快速解决建站难题?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?
如何通过商城免费建站系统源码自定义网站主题?
建站之星后台管理系统如何操作?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
平台云上自主建站:模板化设计与智能工具打造高效网站
如何续费美橙建站之星域名及服务?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
建站主机选哪种环境更利于SEO优化?
常州企业建站如何选择最佳模板?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
建站主机与虚拟主机有何区别?如何选择最优方案?
兔展官网 在线制作,怎样制作微信请帖?
如何解决VPS建站LNMP环境配置常见问题?
MySQL查询结果复制到新表的方法(更新、插入)
如何自定义建站之星模板颜色并下载新样式?
*请认真填写需求信息,我们会在24小时内与您取得联系。