Vue3面包屑效果

代码解释

  1. 模板部分 :使用 visibleBreadcrumbItems 来渲染面包屑项,它会根据点击状态动态显示。
    1. 脚本部分 : - clickedIndex 用于记录点击的面包屑项的索引,初始值为 -1 表示未点击。 - visibleBreadcrumbItems 是一个计算属性,根据 clickedIndex 的值来决定显示哪些面包屑项。如果 clickedIndex-1,则显示全部面包屑项;否则,显示从开始到 clickedIndex 对应的项。 - handleBreadcrumbClick 方法在点击面包屑项时被调用,将 clickedIndex 设置为当前点击项的索引。 这样,当你点击某个面包屑项时,该项之后的所有面包屑项就会消失。
xml 复制代码
<template>
  <nav class="flex space-x-2 items-center text-gray-700">
    <span v-for="(item, index) in visibleBreadcrumbItems" :key="index" class="flex items-center cursor-pointer" @click="handleBreadcrumbClick(index)">
      <span v-if="index > 0" class="mr-2 text-gray-400">/</span>
      <span class="text-sm font-medium hover:text-blue-600 transition-colors duration-200">
        {{ item.title }}
      </span>
    </span>
  </nav>
</template>

<script setup>
import { ref, computed } from 'vue';

// 模拟面包屑数据,可根据实际情况修改
const breadcrumbItems = ref([
  { title: '首页' },
  { title: '分类' },
  { title: '子分类' },
  { title: '当前页面' }
]);

const clickedIndex = ref(-1);

const visibleBreadcrumbItems = computed(() => {
  if (clickedIndex.value === -1) {
    return breadcrumbItems.value;
  }
  return breadcrumbItems.value.slice(0, clickedIndex.value + 1);
});

const handleBreadcrumbClick = (index) => {
  clickedIndex.value = index;
};
</script>

<style scoped>
/* 样式可以根据需求调整 */
.flex {
  display: flex;
}
.space-x-2 > * + * {
  margin-left: 0.5rem;
}
.items-center {
  align-items: center;
}
.text-gray-700 {
  color: #4b5563;
}
.text-gray-400 {
  color: #9ca3af;
}
.text-sm {
  font-size: 0.875rem;
}
.font-medium {
  font-weight: 500;
}
.cursor-pointer {
  cursor: pointer;
}
.hover:text-blue-600:hover {
  color: #2563eb;
}
.transition-colors {
  transition-property: color;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 200ms;
}
</style>    
相关推荐
lichenyang45325 分钟前
鸿蒙 MVVM 实战:从 Demo 到工程化,聊聊登录、状态管理与埋点系统设计
前端
IT_陈寒41 分钟前
Vite打包时遇到的坑,原来问题出在这里
前端·人工智能·后端
kyriewen1 小时前
AI生成代码快如闪电,但我修了三个小时——它到底帮了谁?
前端·javascript·ai编程
ayqy贾杰2 小时前
基层管理的三板斧,在AI时代行不通了
前端·后端·团队管理
Apifox2 小时前
Apifox 5 月更新|Postman 导入优化、Runner 支持非 root 运行、请求代码自动带鉴权
前端·后端·安全
miaowmiaow2 小时前
PSD2Code 近期更新与深度解析:从设计稿到生产级代码的完整技术栈
前端·人工智能·ai编程
Hilaku2 小时前
多标签页并发请求导致 Token 刷新失败?只有 15行代码就能解决 !
前端·javascript·程序员
Nile2 小时前
解密Palantir系列一:4. Ontology 不是哲学
开发语言·前端·javascript
因_崔斯汀3 小时前
ECharts 区域地图可视化实战:以山东地图为例
前端
Bacon3 小时前
手摸手带你搞清楚 AI Agent 的六大核心概念
前端·人工智能