vue3中路由跳转对应菜单高亮,在<script setup>中监听路由变化

本文展示了在Vue3中如何根据当前路由动态设置菜单选中状态,通过`useRouter`和`useRoute`来监听和处理路由变化,实现菜单项的高亮。点击菜单时调用`handleClick`函数更新当前选中索引并进行路由跳转。
摘要由CSDN通过智能技术生成

vue3中路由跳转对应菜单高亮


 <ul class="menu-list">
 	<li v-for="(item, index) in menuList" 
 		:key="item.id" :class="{ 'active': curIndex === index }"
         @click="handleClick(index, item.path)">
       {{ item.title }}
    </li>
</ul>

<script  setup>
import { ref, watchEffect } from "vue";
import { useRouter, useRoute } from 'vue-router'

const menuList = [
    { id: '1', title: '首页', path: '/ly/index' },
    { id: '2', title: '新闻', path: '/ly/news' },
    { id: '3', title: '提问', path: '/ly/question' },
]

const curIndex = ref(0)

const router = useRouter()

const handleClick = (index, path) => {
    curIndex.value = index
    router.push(path)
}

const route = useRoute()
watchEffect(() => {
    curIndex.value = menuList.findIndex(item => item.path == route.path)
})

</script>

下方是我微信公众号的二维码,关于react及其他相关知识点会在公众号上面更新,可以扫码关注以下,有什么问题也可以通过公众号跟我留言哦
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值