vue 中 router.beforeeach 可能走两次,原因有:1. 错误的导航顺序;2. 多个路由守卫;3. vuex 存储变更。为了避免这种情况,应避免在 beforeeach 中执行导航,合并多个路由守卫,并使用 watch 监听 vuex 存储变更。
为什么 Vue 中的 router.beforeEach
会走两次?
router.beforeEach
是 Vue Router 中的一个钩子函数,它会在路由导航发生之前触发。一般情况下,它只会被触发一次,但在某些特定情况下,它可能会被触发两次。
可能的原因:
-
错误的导航顺序:如果在
beforeEach
钩子函数内部执行了路由导航,则该钩子函数将再次触发。这是因为路由导航是一个异步过程,在它完成之前,beforeEach
钩子函数可能已经被执行了。 -
多个路由守卫:如果有多个路由守卫(global 和 per-route)注册了
beforeEach
钩子函数,则它们都会被触发。这可能会导致重复的逻辑或意外行为。 -
Vuex 存储变更:如果
beforeEach
钩子函数依赖于 Vuex 存储的状态,并且在导航期间触发了状态变更,则该钩子函数可能会被再次触发。这是因为 Vuex 存储变更会触发组件重新渲染,这反过来又会导致路由导航。
如何避免:
为了避免 router.beforeEach
触发两次,可以采取以下措施:
-
避免在
beforeEach
钩子函数中执行路由导航:如果需要在beforeEach
钩子函数中执行路由导航,请使用next()
回调来延迟导航,直到当前导航完成。 -
合并多个路由守卫:如果有多个路由守卫需要注册
beforeEach
钩子函数,请考虑将它们合并为一个函数。 -
使用 watch 监听 Vuex 存储变更:如果
beforeEach
钩子函数依赖于 Vuex 存储的状态,请使用 Vuex 的watch()
函数来监听状态变更,而不是在导航期间触发状态变更。
结论:
router.beforeEach
在 Vue 中触发两次通常是由于错误的导航顺序、多个路由守卫或 Vuex 存储变更。通过遵循上述措施,可以避免这种情况,确保 beforeEach
钩子函数按预期执行。
以上就是vue中的router.beforeEach为什么会走两次的详细内容,更多请关注叮当号网其它相关文章!
文章来自互联网,只做分享使用。发布者:老板不要肥肉,转转请注明出处:https://www.dingdanghao.com/article/435656.html