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>

教学地址

点击跳转教学页面

完整源码下载地址

点击跳转下载页面

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

相关推荐
鱼锦0.01 小时前
在vue2中主页面怎么给子页面传递数据
前端·javascript·html
!win !4 小时前
前端跨标签页通信方案(下)
前端·javascript
f***45324 小时前
基于SpringBoot和PostGIS的各省与地级市空间距离分析
android·前端·后端
编码追梦人4 小时前
从 “手忙脚乱“ 到 “行云流水“:华为云 DevUI 与 MateChat 如何让前端开发飞起来
前端·华为云
用户47949283569155 小时前
TypeScript 简史:它是怎么拯救我的烂代码的
javascript·typescript
S***H2835 小时前
前端动画实现经验,性能优化与兼容性
前端
用户47949283569155 小时前
只有前端 Leader 才会告诉你:那些年踩过的模块加载失败的坑(二)
javascript
xw56 小时前
前端跨标签页通信方案(下)
前端·javascript
zzlyx996 小时前
IoTSharp前端VUE采用npm run build编译提示require() of ES Module 出错
前端·vue.js·npm
全栈技术负责人6 小时前
拒绝“无法复现”:前端全链路日志排查实战手册
前端·全链路·问题排查思路