vue 导航面包屑

这是一个关于Vue.js中实现面包屑导航组件的示例代码。当路由变化时,通过`watch`监听更新面包屑列表,并根据当前路由匹配到相应的页面标题。同时,定义了特定的样式使得面包屑导航的显示更加符合设计要求,包括颜色、字体大小和布局等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<template>
 <div class="bread">
   <div class="example-container">
    <el-breadcrumb separator=">">
      <el-breadcrumb-item
        v-for="(item,index) in breadList"
        :key="index"
        :to="{ path: item.path }"
      >{{item.meta.title}}</el-breadcrumb-item>
    </el-breadcrumb>
  </div>
 </div>
</template>
<script>
export default {
  data () {
    return {
      breadList: [] // 路由集合
    }
  },
  watch:{
    $route(){
      this.getBreadcrumb();
    }
  },
  methods: {
    isHome(route) {
      return route.name === "首页";
    },
    getBreadcrumb() {
      let matched = this.$route.matched.filter(item => item.name);
      console.log('eeee1',matched);
      if (!this.isHome(matched[0])) {
        matched = [{ path: "/OnlineEducation/dashboard", meta: { title: "首页" } }].concat(matched);
      }
      this.breadList = matched;
      console.log('wwwww',matched);
    }
  },
   created() {
    this.getBreadcrumb();
  }
}
</script>
<style scoped>
.bread .el-breadcrumb .el-breadcrumb__item:last-child /deep/ .el-breadcrumb__inner{
  color: #1aa972 !important;
}
.bread .el-breadcrumb .el-breadcrumb__item /deep/ .el-breadcrumb__inner{
  color: #999999 !important;
}
.bread  /deep/ .el-breadcrumb{
  display: inline-block;
  display: inline-block;
  height: 48px;
  vertical-align: top;
  line-height: 48px;
  font-size: 20px;
}
.bread /deep/ .is-link{
  font-weight: normal;
}
.bread{
  float:left;
}
</style>
Vue 3 中实现面包屑导航的联动可以通过使用路由钩子和动态路由参数来实现。 首先,你需要在 Vue Router 中设置路由参数。在定义路由时,可以使用冒号(:)来定义动态参数。例如: ```javascript const routes = [ { path: '/category/:categoryId', component: Category }, { path: '/category/:categoryId/product/:productId', component: Product }, ]; ``` 然后,在组件中,你可以使用 `$route.params` 访问路由参数。在面包屑导航组件中,你可以监听 `$route` 的变化,并根据当前路由参数来动态生成面包屑导航。 下面是一个简单的示例: ```vue <template> <div> <ul> <li v-for="crumb in breadcrumbs" :key="crumb.path"> <router-link :to="crumb.path">{{ crumb.label }}</router-link> </li> </ul> </div> </template> <script> export default { computed: { breadcrumbs() { const breadcrumbs = []; const { matched } = this.$route; matched.forEach(route => { const path = route.path; const label = route.meta && route.meta.breadcrumbLabel; if (label) { breadcrumbs.push({ path, label }); } }); return breadcrumbs; } } } </script> ``` 在上面的示例中,我们通过监听 `$route` 的变化,在 `breadcrumbs` 计算属性中根据当前路由的 `matched` 属性来生成面包屑导航的数据。每个路由都可以设置 `meta` 字段来定义面包屑导航的标签。 在路由的定义中,你可以像下面这样设置 `meta` 字段: ```javascript const routes = [ { path: '/category/:categoryId', component: Category, meta: { breadcrumbLabel: 'Category' } }, { path: '/category/:categoryId/product/:productId', component: Product, meta: { breadcrumbLabel: 'Product' } } ]; ``` 这样,当路由发生变化时,面包屑导航组件会根据当前路由的 `matched` 属性动态生成面包屑导航的数据。你可以在模板中使用 `v-for` 指令来渲染面包屑导航的每个项,并使用 `router-link` 组件来生成链接。 希望这个示例对你有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值