Vue基于el-breadcrumb实现面包屑功能(操作代码)

 更新时间:2023年09月06日 16:28:28   作者:别改我bug  
这篇文章主要介绍了Vue基于el-breadcrumb实现面包屑功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

vue3 + elementPlus 实现面包屑功能

文章后面附效果图

数据结构

首先展示一下数据基础结构
红色框框是默认存在的数据,其他数据就是通过选中侧边栏菜单进行数据插入
关键数据字段为 path, meta

在这里插入图片描述

准备侧边栏

首先需要自己准备一个侧边栏这边就不进行讲解,上个效果图

在这里插入图片描述

实现面包屑代码

<template>
// 面包屑组件, separator为分割线,具体可以去elementPlus官网查看
  <el-breadcrumb separator="/">
    <div class="breadcrumb-content">
    	// 动画组件  [官网链接](https://cn.vuejs.org/guide/built-ins/transition.html)
      <transition-group name="breadcrumb">
        <el-breadcrumb-item class="breadcrumb-item" v-for="item in arr.breadCrumbList" :key="item.path">
          <span v-if="item.redirect === route.path">
            {{ item.meta.title }}
          </span>
          <a v-else @click="handleLine(item)">{{ item.meta.title }}</a>
        </el-breadcrumb-item>
      </transition-group>
    </div>
  </el-breadcrumb>
</template>
<script setup lang="ts">
const router = useRouter();
// 面包屑数据
let arr = reactive({
  breadCrumbList: [],
});
const route = useRoute();
// 获取面包屑数据
const getBreadcrumbList = () => {
  arr.breadCrumbList = [];
  route.matched.forEach((item) => {
    if (item.meta.title) arr.breadCrumbList.push(item);
  });
  // 判断是否存在首页默认数据,不存在就插入到数据首位
  if (!arr.breadCrumbList.length || arr.breadCrumbList[0].name !== "Dashboard")
    arr.breadCrumbList.unshift({
      path: "/dashboard/index",
      meta: { title: "首页" },
    });
};
getBreadcrumbList();
// 监听路由变化
watch(route, () => {
  getBreadcrumbList();
});
// 面包屑跳转
const handleLine = ({ redirect, path }) => {
  redirect ? router.push(redirect) : router.push(path);
};
</script>
<style lang="less" scoped>
.el-breadcrumb {
  display: flex;
  padding-left: 10px;
  line-height: 50px;
  background-color: #f6f6f6;
}
.breadcrumb-item {
  margin-left: 8px;
}
.breadcrumb-content {
  position: relative;
}
.breadcrumb-enter-active,
.breadcrumb-leave-active {
  transition: all 0.5s;
}
.breadcrumb-enter-from,
.breadcrumb-leave-active {
  opacity: 0;
}
.breadcrumb-move {
  transition: all 0.5s;
}
.breadcrumb-leave-active {
  position: absolute;
  right: -50px;
}
</style>

效果图

在这里插入图片描述

到此这篇关于Vue基于el-breadcrumb实现面包屑功能的文章就介绍到这了,更多相关vue面包屑内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解axios在vue中的简单配置与使用

    详解axios在vue中的简单配置与使用

    本篇文章主要介绍了详解axios在vue中的简单配置与使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 移动端Vue2.x Picker的全局调用实现

    移动端Vue2.x Picker的全局调用实现

    这篇文章主要介绍了移动端Vue2.x Picker的全局调用实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Vite vue如何使用cdn引入element-plus

    Vite vue如何使用cdn引入element-plus

    这篇文章主要介绍了Vite vue使用cdn引入element-plus的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • vue请求本地自己编写的json文件的方法

    vue请求本地自己编写的json文件的方法

    这篇文章主要介绍了vue请求本地自己编写的json文件,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-04-04
  • Vue在chrome44偶现点击子元素事件无法冒泡的解决方法

    Vue在chrome44偶现点击子元素事件无法冒泡的解决方法

    这篇文章主要给大家介绍了关于Vue在chrome44偶现点击子元素事件无法冒泡的解决方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Vue具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-12-12
  • vue单页开发父子组件传值思路详解

    vue单页开发父子组件传值思路详解

    这篇文章主要介绍了vue单页开发父子组件传值思路详解,本文是小编抽空整理的思路,感兴趣的朋友跟随脚本之家小编一起学习吧
    2018-05-05
  • vue+vux vux安装出现错误问题及解决

    vue+vux vux安装出现错误问题及解决

    这篇文章主要介绍了vue+vux vux安装出现错误问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Vue3中使用Supabase Auth方法详解

    Vue3中使用Supabase Auth方法详解

    这篇文章主要为大家介绍了Vue3中使用Supabase Auth方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • 详解vue+vuex+koa2开发环境搭建及示例开发

    详解vue+vuex+koa2开发环境搭建及示例开发

    本篇文章主要介绍了详解vue + vuex + koa2开发环境搭建及示例开发,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Vue实现input宽度随文字长度自适应操作

    Vue实现input宽度随文字长度自适应操作

    这篇文章主要介绍了Vue实现input宽度随文字长度自适应操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07

最新评论