uniapp Vue3 面包屑导航 带动态样式

上干货

复制代码
<template>
  <view class="bei">
    <view class="container">
      <view class="indicator"></view>
      <!-- 遍历路由列表 -->
      <view v-for="(item, index) in routes" :key="index" :class="['foritem', {'selected': item.to === selectedRoute}]" @click="dianji(item)">
        <view class="item">
          {{ item.name }}
        </view>
      </view>
    </view>
  </view>
  <view class="tip" v-if="selectedPage == 'A'">
    您已转到 {{ selectedPage }} 页面
  </view>
  <view class="tip" v-if="selectedPage == 'B'">
    您已转到 {{ selectedPage }} 页面
  </view>
  <view class="tip" v-if="selectedPage == 'C'">
    您已转到 {{ selectedPage }} 页面
  </view>
</template>

<script setup>
  import { onMounted, ref } from "vue"

  // 定义路由列表
  const routes = ref([
    {
      to: "A",
      name: "A页面",
    },
    {
      to: "B",
      name: "B页面",
    },
    {
      to: "C",
      name: "C页面",
    },
  ])
  // 当前选中的路由
  const selectedRoute = ref("")
  // 当前选中的页面
  const selectedPage = ref("")


  // 点击路由项的处理函数
  function dianji(item) {
    console.log("点击", item.to)
    selectedRoute.value = item.to
    selectedPage.value = item.to
    const index = routes.value.findIndex(route => route.to === item.to)
  }

  // 组件挂载后的初始化
  onMounted(() => {
    selectedRoute.value = "A" // 将"A页面"设置为被点击状态
    selectedPage.value = "A" // 设置初始提示信息
  })
</script>

教学地址

点击跳转教学页面

完整源码下载地址

点击跳转下载页面

也可以添加下方的名片进行咨询

相关推荐
一点一木8 小时前
深度体验TRAE SOLO移动端7天:作为独立开发者,我把工作流揣进了兜里
前端·人工智能·trae
天外飞雨道沧桑8 小时前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
Lee川9 小时前
mini-cursor 揭秘:从 Tool 定义到 Agent 循环的完整实现
前端·人工智能·后端
canonical_entropy9 小时前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香9 小时前
聊聊前端页面的三种长度单位
前端
给钱,谢谢!10 小时前
React + PixiJS 实现果园成长页:从状态机到浇水动画
前端·react.js·前端框架
暗冰ཏོ11 小时前
VUE面试题大全
前端·javascript·vue.js·面试
次元工程师!11 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
Bug-制造者12 小时前
现代Web应用全栈开发:从架构设计到部署落地实战
前端
青春喂了后端12 小时前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式