一.原因:
vue-router的切换不同于传统的页面的切换。路由之间的切换,其实就是组件之间的切换,不是真正的页面切换。这也会导致一个问题,就是引用相同组件的时候,由于参数不一样不会覆盖原打开的页面而会打开一个重复的页面,只是页面的数据不一样,再点开旧的页面时(B.1)发现数据还是新页面(B.2)的数据,点开旧页面(B.1)时不会调用created(),mounted()函数,会导致获取数据的函数无法调用从而该组件无法更新。
已知:
父组件A页面跳转方式:
this.$router.push({
path:'/task/recordList',
query: {'id': row.id}
})
二.解决方法:
在父组件B页面:
在watch中设置路由监听:通过监听$route.query.id
这个参数
(关键设置)
watch: {
'$route.query.id' (to, from) { //监听路由是否变化
if(this.$route.path == '/psm/psmUser'){//仅在当前页面生效
if(to != from){
this.queryParams.taskId = to;
this.getList();//重新加载数据
}
}
}
},
原作者:不爱去冒险的少年y
原链接:https://www.jianshu.com/p/af51253327f2