官方对于beforeRouteUpdate的解释如下:beforeRouteUpdate (to, from, next) {// 在当前路由改变,但是该组件被复用时调用// 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,...
官方对于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不执行,页面不刷新的解决办法
参考:https://segmentfault.com/q/1010000015823449
本文标题为:vue-router的beforeRouteUpdate不触发
基础教程推荐
- Ajax实现简单下拉选项效果【推荐】 2022-12-28
- html网页中使用希腊字母的方法 2022-09-21
- vue在install时node-sass@4.14.1 postinstall:node scripts/build.js错误解决 2023-07-09
- JavaScript开发简单易懂的Svelte实现原理详解 2023-08-12
- 使用HTML5中postMessage知识点解决Ajax中POST跨域问题 2022-10-17
- ajax异步加载图片实例分析 2022-12-18
- JavaScript函数this指向问题详解 2023-08-12
- Ajax实现关键字联想和自动补全功能及遇到坑 2023-02-23
- 【vue】三种获取input值的写法 2023-10-08
- AJAX实现数据的增删改查操作详解【java后台】 2023-02-23
