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 相关文章推荐
JS控制弹出新页面窗口位置和大小的方法
Mar 02 Javascript
Bootstrap 附加导航(Affix)插件实例详解
Jun 01 Javascript
Javascript 引擎工作机制详解
Nov 30 Javascript
ES6通过babel转码使用webpack使用import关键字
Dec 13 Javascript
js+html制作简单验证码
Feb 16 Javascript
详解从Node.js的child_process模块来学习父子进程之间的通信
Mar 27 Javascript
JS简单获取并修改input文本框内容的方法示例
Apr 08 Javascript
tracking.js页面人脸识别插件使用方法
Apr 16 Javascript
vue+element+Java实现批量删除功能
Apr 08 Javascript
微信小程序进入广告实现代码实例
Sep 19 Javascript
微信小程序中的video视频实现 自定义播放按钮、封面图、视频封面上文案
Jan 02 Javascript
在vue中通过render函数给子组件设置ref操作
Nov 17 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 addslashes和mysql_real_escape_string
2010/01/24 PHP
linux下使用crontab实现定时PHP计划任务失败的原因分析
2014/07/05 PHP
Linux系统递归生成目录中文件的md5的方法
2015/06/29 PHP
php使用curl模拟多线程实现批处理功能示例
2019/07/25 PHP
js验证表单大全
2006/11/25 Javascript
Javascript的一种模块模式
2008/03/22 Javascript
通过jquery的$.getJSON做一个跨域ajax请求试验
2011/05/03 Javascript
ExtJS4 Grid改变单元格背景颜色及Column render学习
2013/02/06 Javascript
Jquery.addClass始终无效原因分析
2013/09/08 Javascript
javascript限制用户只能输汉字中文的方法
2014/11/20 Javascript
JavaScript实现页面无操作倒计时退出
2016/10/22 Javascript
js 开发之autocomplete=&quot;off&quot;在chrom中失效的解决办法
2017/09/28 Javascript
微信小程序wx.uploadfile 本地文件转base64的实现代码
2018/06/28 Javascript
从vue源码解析Vue.set()和this.$set()
2018/08/30 Javascript
JavaScript中while循环的基础使用教程
2020/08/11 Javascript
python基础教程之基本内置数据类型介绍
2014/02/20 Python
举例讲解Python设计模式编程中的访问者与观察者模式
2016/01/26 Python
python 申请内存空间,用于创建多维数组的实例
2019/12/02 Python
pymysql模块的操作实例
2019/12/17 Python
Python 实现自动获取种子磁力链接方式
2020/01/16 Python
Pytorch损失函数nn.NLLLoss2d()用法说明
2020/07/07 Python
浅析HTML5中header标签的用法
2016/06/24 HTML / CSS
Banggood官网:面向全球客户的综合商城
2017/04/19 全球购物
公司前台辞职报告
2014/01/19 职场文书
教师研修随笔感言
2014/01/23 职场文书
个人简历中的自我评价怎么写
2014/01/26 职场文书
班主任评语大全
2014/04/26 职场文书
投标诚信承诺书
2014/05/26 职场文书
2014年无财产无子女离婚协议书范本
2014/10/09 职场文书
学校德育工作总结2015
2015/05/11 职场文书
《失物招领》教学反思
2016/02/20 职场文书
Python基础之pandas数据合并
2021/04/27 Python
python基于turtle绘制几何图形
2021/06/15 Python
Python 中 Shutil 模块详情
2021/11/11 Python
Win11 S Mode版本泄露 正式上线后叫做Windows 11 SE
2021/11/21 数码科技
pytorch实现加载保存查看checkpoint文件
2022/07/15 Python