欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue2.0 elementUI制作面包屑导航栏

程序员文章站 2022-09-16 17:38:01
main.js var routelist = []; router.beforeeach((to, from, next) => { var ind...

main.js

var routelist = [];
router.beforeeach((to, from, next) => {
 var index = -1;
 for(var i = 0; i < routelist.length; i++) {
  if(routelist[i].name == to.name) {
   index = i;
   break;
  }
 }
 if (index !== -1) {
//如果存在路由列表,则把之后的路由都删掉
  routelist.splice(index + 1, routelist.length - index - 1);
 } else if(to.name != '登录'){
  routelist.push({"name":to.name,"path":to.fullpath});
 }
 to.meta.routelist = routelist;
 next()
});

2、在要使用的组件中

<template>
  <div class="level-bread">
   <el-breadcrumb separator="/">
    <el-breadcrumb-item v-for="item in reallist" :to="item.path">{{item.name}}</el-breadcrumb-item>
   </el-breadcrumb>
  </div>
</template>

<script>
  export default {
   name: "lelve-bread",
   created(){
    this.getroutepath();
   },
   data() {
    return {
     reallist: []
    }
   },
   methods:{
    getroutepath() {
     this.reallist = this.$route.meta.routelist;
    }
   },
   beforerouteenter(to,from, next) {
    next((vm) => {
     vm.reallist = to.meta.routelist;
    });
   },
   // watch:{
   //  $route:function(newv,oldv) {
   //   this.reallist =newv.meta.routelist;
   //  }
   // }
  }
</script>

用 watch 或者 beforerouteenter 均可。

需要注意的是,beforerouteenter 此时访问不到this。

const foo = {
 template: `...`,
 beforerouteenter (to, from, next) {
  // 在渲染该组件的对应路由被 confirm 前调用
  // 不!能!获取组件实例 `this`
  // 因为当守卫执行前,组件实例还没被创建
 },
 beforerouteupdate (to, from, next) {
  // 在当前路由改变,但是该组件被复用时调用
  // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
  // 由于会渲染同样的 foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
  // 可以访问组件实例 `this`
 },
 beforerouteleave (to, from, next) {
  // 导航离开该组件的对应路由时调用
  // 可以访问组件实例 `this`
 }
}

以上就是本次我们整理的全部内容,希望能够帮助到大家,感谢大家对的支持。