Vue通过ID修改URL复用同一个页面/组件,不重新加载的问题以及版本Vue版本升级导致的Uncaught (in promise)问题

在项目中经常会用到同一个页面,结构是相同的,只是

vue-router中通过添加参数的方式来区分状态,参数可以在页面跳转时带上params,或者query,但是即使我们修改了参数,URL也显示已经改变,但页面并不会刷新,因为路由是相同的,vue就会认为你是同一个页面,从而复用已加载的页面,而不会重新加载,可以通过watch监听事件来监听路由的变化:

  watch: {
    $route(to, from) {
      if (to.name === "account") {
        // 在此调用函数,如:
        this.getAccountInfo();
      }
    }
  },

但是又出现了新的错误:

这是因为vue-router的版本问题

解决方法: 

1、可以降低vue-router的版本试试

2、在调用方法的时候用catch捕获异常

3、在vue-router的配置文件(默认是router/index.js中)中重写路由的push方法

const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location, onResolve, onReject) {
  if (onResolve || onReject) return originalPush.call(this, location, onResolve, onReject)
  return originalPush.call(this, location).catch(err => err)
}

 以上是自己踩坑的一些记录

感谢以下博客主:

vue通过ID(参数)修改URL复用同一个页面(组件)不重新加载的问题 

vue-router升级导致的Uncaught(in promise)问题

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值