vue3.x:route路径相同参数不同页面不刷新解决

本文介绍了如何在Vue.js应用中使用`useRouter`和`useRoute`钩子来管理路由,重点讲解了`<router-view key=route.fullPath>`的用法,适合前端开发者理解Vue Router的基本操作。
<router-view :key="route.fullPath"></router-view

JS中

import { useRouter, useRoute } from 'vue-router'
const router = useRouter()
const route = useRoute()
Uncaught (in promise) RangeError: Maximum call stack size exceeded at String.replace (<anonymous>) at encode (vue-router.esm.js:45:6) at eval (vue-router.esm.js:140:16) at Array.map (<anonymous>) at stringifyQuery (vue-router.esm.js:114:8) at getFullPath (vue-router.esm.js:218:26) at createRoute (vue-router.esm.js:172:15) at _createRoute (vue-router.esm.js:1730:12) at Object.match (vue-router.esm.js:1632:12) at VueRouter.match (vue-router.esm.js:2948:23) encode @ vue-router.esm.js:45 eval @ vue-router.esm.js:140 stringifyQuery @ vue-router.esm.js:114 getFullPath @ vue-router.esm.js:218 createRoute @ vue-router.esm.js:172 _createRoute @ vue-router.esm.js:1730 match @ vue-router.esm.js:1632 match @ vue-router.esm.js:2948 transitionTo @ vue-router.esm.js:2259 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095 runQueue @ vue-router.esm.js:2103 confirmTransition @ vue-router.esm.js:2400 transitionTo @ vue-router.esm.js:2268 replace @ vue-router.esm.js:2739 eval @ vue-router.esm.js:2386 eval @ permissions.js:64 iterator @ vue-router.esm.js:2370 step @ vue-router.esm.js:2095了解此错误
最新发布
07-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值