vue-router的beforeRouteUpdate不触发问题
作者:PrinciplesMan
这篇文章主要介绍了vue-router的beforeRouteUpdate不触发问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
vue-router beforeRouteUpdate不触发
官方对于beforeRouteUpdate的解释如下:
beforeRouteUpdate (to, from, next) { // 在当前路由改变,但是该组件被复用时调用 // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候, // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。 // 可以访问组件实例 `this` },
不能触发的原因可以看注释的第二、三行,只有动态参数的路径(/foo/1 和 /foo/2这样),才会调用。
我尝试对router动态处理
vue.$router.push({ path: path , query: { t: (new Date()) }});
这个场景下,beforeRouteUpdate成功触发。
可以考虑修改你的router-link写法,加个参数,代码示例如下:
<router-link :to="{path:'/home',query: {t: new Date()}}">首页</router-link>
当然,最主要的是,这个方法是组件内的导航守卫,切换路由组件,按你目前的代码功能来看,如果想触发,
除了router-link要带参数,还需要修改router-view
<keep-alive> <router-view></router-view> </keep-alive>
另外可以采用如下解决办法:
watch: { $route(to, from) { console.log(to); console.log(from); } }
同样试用 vue-router路由跳转created不执行,页面不刷新的解决办法
beforeRouteEnter和beforeRouteUpdate的坑
beforeRouteEnter是新进入的一个路由,比如进入/login登录界面,会触发beforeRouteEnter这个钩子;
而beforeRouteUpdate是路由更新时触发,从主页进入登录界面不会触发这个钩子函数,一个父路由下的子路由跳转会触发这个钩子函数。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。