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 相关文章推荐
JavaScript高级程序设计 事件学习笔记
Sep 10 Javascript
分享精心挑选的23款美轮美奂的jQuery 图片特效插件
Aug 14 Javascript
js使用split函数按照多个字符对字符串进行分割的方法
Mar 20 Javascript
js+html5获取用户地理位置信息并在Google地图上显示的方法
Jun 05 Javascript
JavaScript计算某一天是星期几的方法
Aug 05 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
Aug 21 Javascript
微信小程序之电影影评小程序制作代码
Aug 03 Javascript
深入理解Vue.js源码之事件机制
Sep 27 Javascript
Vue项目安装插件并保存
Jan 28 Javascript
微信小程序实现页面浮动导航
Jan 28 Javascript
vue中通过使用$attrs实现组件之间的数据传递功能
Sep 01 Javascript
ES11新增的这9个新特性,你都掌握了吗
Oct 15 Javascript
基于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
星际原理概述
2020/03/04 星际争霸
MySQL授权问题总结
2007/05/06 PHP
PHP 获取MySQL数据库里所有表的实现代码
2011/07/13 PHP
PHP实现简单爬虫的方法
2015/07/29 PHP
php中替换字符串函数strtr()和str_repalce()的用法与区别
2016/11/25 PHP
PHP数据库编程之MySQL优化策略概述
2017/08/16 PHP
实现png图片和png背景透明(支持多浏览器)的方法
2009/09/08 Javascript
防止动态加载JavaScript引起的内存泄漏问题
2009/10/08 Javascript
两个JavaScript jsFiddle JSBin在线调试器
2010/03/14 Javascript
javascript得到当前页的来路即前一页地址的方法
2014/02/18 Javascript
JavaScript时间操作之年月日星期级联操作
2016/01/15 Javascript
使用JQuery中的trim()方法去掉前后空格
2016/09/16 Javascript
js实现一键复制功能
2017/03/16 Javascript
jquery DataTable实现前后台动态分页
2017/06/17 jQuery
Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案
2018/05/15 Javascript
vue ssr 实现方式(学习笔记)
2019/01/18 Javascript
vue中created和mounted的区别浅析
2019/08/13 Javascript
vue组件命名和props命名代码详解
2019/09/01 Javascript
React中使用Vditor自定义图片详解
2020/12/25 Javascript
开源Web应用框架Django图文教程
2017/03/09 Python
Python网络编程之TCP套接字简单用法示例
2018/04/09 Python
python3解析库lxml的安装与基本使用
2018/06/27 Python
Python实现从SQL型数据库读写dataframe型数据的方法【基于pandas】
2019/03/18 Python
Python使用lambda表达式对字典排序操作示例
2019/07/25 Python
一行python实现树形结构的方法
2019/08/09 Python
使用TensorFlow-Slim进行图像分类的实现
2019/12/31 Python
python 使用递归实现打印一个数字的每一位示例
2020/02/27 Python
django修改models重建数据库的操作
2020/03/31 Python
希尔顿酒店官方网站:Hilton Hotels
2017/06/01 全球购物
复古斯堪的纳维亚儿童服装:Baby go Retro
2017/09/09 全球购物
澳大利亚个性化儿童礼品网站:Bright Star Kids
2019/06/14 全球购物
《生命 生命》教学反思
2014/04/19 职场文书
计生工作先进事迹
2014/08/15 职场文书
旗帜观后感
2015/06/08 职场文书
导游词之湖州-太湖
2019/10/11 职场文书
Spring Cloud OpenFeign模版化客户端
2022/06/25 Java/Android