Vue下URL地址栏参数改变却不能刷新界面

在完成毕业设计(基于Vue的信息资讯展示与管理平台)的过程中,处理如下图所示的 点击左侧栏目列表跳转到对应文章列表 的问题时,初次点击可以跳转到对应的页面,但是当第二次点击时,虽然地址栏的参数改变了,也没有重新刷新页面中的内容。

 

第1次,点击“潮科技”时显示的内容:

 

 第2次,点击“奇趣事”时显示的内容:

 

造成上述情况的原因

  • vue项目中路由跳转默认采用hash的方式,而hash的变化不会导致浏览器发送请求到服务器;
  • 将获取数据的的函数的执行放在了Vue生命周期函数 mounted() 中,组件初次加载时执行了 mounted() 函数中的内容,但是再次点击时只有参数变化,组件已经挂载结束而且不会重新加载,mounted()  中的内容当然也就不会重新执行了。

 

解决方案:使用侦听器监听URL地址栏参数变化

当侦听器监听到URL地址栏参数变化时,调用获取数据列表的函数 getDate()

watch: {
    '$route' (to, from) {
        this.getData(this.$route.query.id)
    }
}

   

methods: {
    async getData (id) {
      // 按照id获取数据
      const { data: { result } } = await this.$http.get('getShowList', {
        params: { id }
      })
      this.dataList = result
    }
}

  

通过这种方式,就能使页面内容随着参数变化而变化了,如下图所示:

 

 

转载于:https://www.cnblogs.com/belongs-to-qinghua/p/10944400.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值