解决Vue3+uni-app导航栏高亮自动同步方案

路由跳转自动识别导航高亮实现方法

以下代码使用wd-tabbar组件实现路由跳转时自动同步导航栏高亮状态,适用于所有的Vue3+uni-app项目。 请根据自身使用框架类型完成,也可根据我使用的UI组件进行完成地址如下:

Tabbar 标签栏 | Wot UI ,如需使用请按照Wot UI先进行安装后可直接粘贴复制我的代码!

感谢各位尊敬的VIP用户的支持,如果有帮助到您,还请您给一个宝贵的赞!

html 复制代码
<template>
  <view>
    <wd-tabbar fixed v-model="navIndex" bordered safeAreaInsetBottom placeholder shape="round">
      <wd-tabbar-item
        v-for="(item, index) in tabbarList"
        :key="index"
        @click="navBarRule(index)"
        :title="item.title"
        :icon="item.icon"
        :value="item.value"
        :is-dot="item.isDot"
      ></wd-tabbar-item>
    </wd-tabbar>
  </view>
</template>
typescript 复制代码
<script setup lang="ts">
import { ref, computed } from 'vue';

const navIndex = ref(0);
const tabbarList = ref([
  {
    title: '订单中心',
    icon: 'list',
    value: 2,
    isDot: true,
    path: '/pages/view/order-center/index'
  },
  {
    title: '用户管理',
    icon: 'user',
    value: null,
    isDot: false,
    path: '/pages/view/user-manager/index'
  },
  {
    title: '数据流水',
    icon: 'chart-bar',
    value: null,
    isDot: false,
    path: '/pages/view/data-statement/index'
  },
  {
    title: '聊天',
    icon: 'chat',
    value: 200,
    isDot: false,
    path: '/pages/view/chat/index'
  },
  {
    title: '店主中心',
    icon: 'app',
    value: 10,
    isDot: false,
    path: '/pages/view/store-owner/index'
  }
]);

const navBarRule = (index: number) => {
  uni.reLaunch({
    url: tabbarList.value[index].path
  });
  navIndex.value = index;
};

const currentRoute = computed(() => {
  const pages = getCurrentPages();
  return pages[pages.length - 1]?.route || '';
});

navIndex.value = tabbarList.value.findIndex(
  (item) => item.path === `/${currentRoute.value}`
);
</script>

关键实现要点

  • 通过getCurrentPages()获取当前页面栈信息,计算当前路由路径
  • 使用computed属性动态跟踪路由变化
  • 在组件初始化时同步导航栏选中状态
  • 点击导航栏时使用uni.reLaunch进行路由跳转并更新选中状态

注意事项

  • 确保tabbarList中的path与实际路由路径完全匹配
  • 该实现适用于底部导航栏场景,顶部导航需调整样式
  • 使用uni.reLaunch会关闭所有页面并打开新页面,如需保留页面栈可使用uni.navigateTo

该方案已通过实际项目验证,能稳定实现路由与导航栏状态同步。

如果和我的不同情况下,只要您已经完成了导航组件的搭建,在代码中添加

const currentRoute = computed(() => {

const pages = getCurrentPages();

return pages[pages.length - 1]?.route || '';

});

navIndex.value = tabbarList.value.findIndex(

(item) => item.path === `/${currentRoute.value}`

);

这段关键性代码即可,最后需要根据你声明的变量进行替换

相关推荐
dy17171 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
2501_915918415 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂5 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技5 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育
gnip5 小时前
JavaScript二叉树相关概念
前端
一朵梨花压海棠go6 小时前
html+js实现表格本地筛选
开发语言·javascript·html·ecmascript
attitude.x6 小时前
PyTorch 动态图的灵活性与实用技巧
前端·人工智能·深度学习
β添砖java6 小时前
CSS3核心技术
前端·css·css3
空山新雨(大队长)7 小时前
HTML第八课:HTML4和HTML5的区别
前端·html·html5