Vue动态面包屑功能的实现方法


Posted in Javascript onJuly 01, 2019

面包屑应该是我们在项目中经常使用的一个功能,一般情况下它用来表示我们当前所处的站点位置,也可以帮助我们能够更快的回到上个层级。

今天我们就来聊聊如何在 Vue 的项目中实现面包屑功能。以下案例都是使用 Element-UI 进行实现。

最笨的方式

首先我们想到的最笨的方法就是在每个需要面包屑的页面中固定写好。

<template>
 <div class="example-container">
  <el-breadcrumb separator="/">
   <el-breadcrumb-item
    v-for="(item,index) in breadList"
    :key="index"
    :to="{ path: item.path }"
   >{{item.name}}</el-breadcrumb-item>
  </el-breadcrumb>
 </div>
</template>
<script>
export default {
 name: "Example",
 data() {
  return {
   breadList: [{
     name: "首页",
     path: "/home"
    }, {
     name: "系统设置",
     path: "/setting"
    }, {
     name: "用户管理",
     path: "/setting/usermanage"
    }]
  };
 }
};
</script>

如果按照上述方式去实行的话,虽然我们可以完成面包屑的功能,但是它不够灵活,在每个需要的页面添加,带来的维护成本是巨大的。

最主要的是你们的产品天天变需要咋办,还不累死。有人说登哥我就喜欢这么改,只有这样我才会有工作量。

好吧那当我没说,但是我劝你善良,登哥劝你一句,把那些大量重复的工作尽可能的赶紧做完,剩下的时间你才能自由安排,进行充能呀。

否则,你拿什么进步?普通的人总是喜欢抱怨没有时间,而优秀的人就是这么把时间省下来的。他们知道什么事情重要,什么事情不重要。

不过还是有人会说我就想安安静静写写代码,其他的我不想。那也行,不过这样写显然不够逼格。

利用 路由元信息

上面的方法,非常的不够逼格,显然不是我们想要的,那我们再来看看第二种实现方式。

我们可以把路径结构配置在 Route meta 属性中。

const router = new Router({
 routes: [{
   path: '/example',
   name: 'example',
   component: Example,
   meta: {
    breadList: [{
      name: "首页",
      path: "/home"
     }, {
      name: "系统设置",
      path: "/setting"
     }, {
      name: "用户管理",
      path: "/setting/usermanage"
     }]
   }
  }
 ]
});
export default router;

然后我们直接在页面中使用计算属性获取数据。

<template>
 //...省略
</template>
<script>
export default {
 name: "Example",
 computed: {
  breadList() {
   return this.$route.meta.breadList || [];
  }
 }
};
</script>

这样也能实现我要想的效果,但是这个还是显得比较冗余,路由数据已经定义好一次结构,还要加上一个专门的面包屑数据,造成代码的重复,还是不够逼格。

那接下来登哥教你一招比较有逼格的。准备好小本本记下来。

路由对象 matched 属性

首先我们先来看看官方对 matched 的介绍。

matched:返回一个数组,包含当前路由的所有嵌套路径片段的路由记录 。

可以看到当我们定义好路由结构以后,我们就可以获取到当前页面的路由记录。

首先我们先创建一个面包屑的组件。

//Breadcrumb.vue
<script>
export default {
 data() {
  return {
   breadList: [] // 路由集合
  };
 },
 watch: {
  $route() {
   this.getBreadcrumb();
  }
 },
 methods: {
  isHome(route) {
   return route.name === "home";
  },
  getBreadcrumb() {
   let matched = this.$route.matched;
   //如果不是首页
   if (!this.isHome(matched[0])) {
    matched = [{ path: "/home", meta: { title: "首页" } }].concat(matched);
   }
   this.breadList = matched;
  }
 },
 created() {
  this.getBreadcrumb();
 }
};
</script>

创建完组件之后,在需要的地方注入即可。如果你的网页结构布局合理恰当的话只需要一处引用就可以所有网页使用啦。

真可谓 “一处代码供全局”。

定义的路由信息如下:

const router = new Router({
 routes: [
  {
   path: '/',
   redirect: '/home'
  },
  {
   path: '/home',
   name: 'home',
   component: Home,
   meta: { title: '首页' }
  },
  {
   path: '/setting',
   name: "setting",
   component: () => import('./views/setting/Setting.vue'),
   redirect: '/setting/user',
   meta: { title: '系统设置' },
   children: [{
    path: 'user',
    component: () => import('./views/setting/UserMange.vue'),
    name: 'usermanage',
    meta: { title: '用户管理' }
   }, {
    path: 'message',
    component: () => import('./views/setting/MesMange.vue'),
    name: 'mesmanage',
    meta: { title: '短信管理' }
   }]
  },
  {
   path: '/example',
   name: 'example',
   component: Example,
   meta: { title: '综合实例' }
  }
 ]
});
export default router;

可以看到我们非常灵活的实现出我们需要的效果。可能这个功能并没有完善,比如有些页面不需要怎么办?

其实只要我们过滤下数据就可以实现,比如利用 meta 不存在时面包屑数据置空,或者增加一个数据标示面包屑的现实隐藏。等等都是一种思路。小伙伴们不妨发挥自己的想象试试吧。

看十遍不如自己撸一遍。这样很快就能掌握知识点。最后上下效果图给大家观摩。

Vue动态面包屑功能的实现方法

总结

以上所述是小编给大家介绍的Vue动态面包屑功能的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
索趣科技的答案
Feb 07 Javascript
基于jQuery的简单的列表导航菜单
Mar 02 Javascript
Javascript中的String对象详谈
Mar 03 Javascript
Javascript前端UI框架Kit使用指南之Kitjs简介
Nov 28 Javascript
Jquery使用小技巧汇总
Dec 29 Javascript
vue.js+Element实现表格里的增删改查
Jan 18 Javascript
react-native DatePicker日期选择组件的实现代码
Sep 12 Javascript
ES6扩展运算符用法实例分析
Oct 31 Javascript
element-ui表格列金额显示两位小数的方法
Aug 24 Javascript
pm2启动ssr失败的解决方法
Jun 29 Javascript
多个vue子路由文件自动化合并的方法
Sep 03 Javascript
如何在Vue中抽离接口配置文件
Oct 31 Javascript
vue实现自定义H5视频播放器的方法步骤
Jul 01 #Javascript
基于Vue SEO的四种方案(小结)
Jul 01 #Javascript
JavaScript一元正号运算符示例代码
Jun 30 #Javascript
重学JS之显示强制类型转换详解
Jun 30 #Javascript
JavaScript判断浏览器运行环境的详细方法
Jun 30 #Javascript
微信小程序如何自定义table组件
Jun 29 #Javascript
微信小程序如何调用图片接口API并居中显示
Jun 29 #Javascript
You might like
第二节--PHP5 的对象模型
2006/11/16 PHP
利用PHP实现图片等比例放大和缩小的方法详解
2013/06/06 PHP
解析php常用image图像函数集
2013/06/24 PHP
PHP递归调用数组值并用其执行指定函数的方法
2015/04/01 PHP
JavaScript中的Window窗口对象
2008/01/16 Javascript
document.documentElement的一些使用技巧
2013/04/18 Javascript
jquery中.add()的使用分析
2013/04/26 Javascript
利用函数的惰性载入提高javascript代码执行效率
2014/05/05 Javascript
浅谈String.valueOf()方法的使用
2016/06/06 Javascript
Javascript中内建函数reduce的应用详解
2016/10/20 Javascript
BootStrap Fileinput的使用教程
2016/12/30 Javascript
VUE子组件向父组件传值详解(含传多值及添加额外参数场景)
2020/09/01 Javascript
Python基于分水岭算法解决走迷宫游戏示例
2017/09/26 Python
Python中sort和sorted函数代码解析
2018/01/25 Python
Python中将dataframe转换为字典的实例
2018/04/13 Python
Python+selenium实现自动循环扔QQ邮箱漂流瓶
2018/05/29 Python
基于wxPython的GUI实现输入对话框(2)
2019/02/27 Python
选择Python写网络爬虫的优势和理由
2019/07/07 Python
10个Python面试常问的问题(小结)
2019/11/20 Python
Python模块future用法原理详解
2020/01/20 Python
HTML5仿微信聊天界面、微信朋友圈实例代码
2018/01/29 HTML / CSS
Java里面有没有全局变量?为什么?
2015/02/06 面试题
小学教师的个人自我鉴定
2013/10/24 职场文书
毕业研究生的自我鉴定
2013/11/30 职场文书
大型晚会策划方案
2014/02/06 职场文书
环保倡议书50字
2014/05/15 职场文书
大学生求职信范文
2014/05/24 职场文书
十佳家长事迹材料
2014/08/26 职场文书
党的群众路线教育实践活动专题组织生活会发言材料
2014/10/17 职场文书
2014年大学生工作总结
2014/11/20 职场文书
网络安全倡议书(3篇)
2019/09/18 职场文书
nginx限制并发连接请求数的方法
2021/04/01 Servers
如何使用flask将模型部署为服务
2021/05/13 Python
python 如何在list中找Topk的数值和索引
2021/05/20 Python
浅谈Python3中datetime不同时区转换介绍与踩坑
2021/08/02 Python
Windows 11要来了?微软文档揭示Win11太阳谷 / Win10有两个不同版本
2021/11/21 数码科技