vue路由跳转已打开页面不刷新数据

一.原因:

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

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值