vue中监听路由参数变化

在vue项目中,假使我们在同一个路由下,只是改变路由后面的参数值,期望达到数据的更新。

mounted: () =>{
      this.id = this.$route.query.id;
      this.getdetail()
}

getDetail()方法中会用到this.id这个参数,在同一页面切换id的值,并不会触发vue的声明周期函数。

可以添加路由监听:

复制代码
watch: {
    $route: { // 亲测有效,我是用来监听query参数变化
          handler() {
              this.id = this.$route.query.id;
              this.getDetail();
              //深度监听,同时也可监听到param参数变化
        },
        deep: true,
    }
  }     
复制代码

 原文:https://www.cnblogs.com/gxp69/p/11994481.html

原文地址:https://www.cnblogs.com/mmzuo-798/p/12870838.html