vue2 页面跳转时, 如何不再执行当前页面ajax的回调函数啊 ?

阿飞i
  • 628

有时候网络不好的时候. 一个页面的请求往往需要很长时间才响应 . 这时候用户已经跳转到另一个页面.. 此时之前那个响应成功. 执行回调函数...

这时候会给用户造成误解.... 以为是当前此时此刻这个页面给出的一些信息... 比如:报错

回复
阅读 3k
2 个回答

这样的话,建议在ajax的回调函数中写上一些判断就好,比如:可以判断当前路由是都是进行ajax请求时的路由,如果

是,那么执行回调,如果不是就return出来就好了。

有个思路,可以参考。
如果是原生 XmlHttpRequest 对象,可以直接调用 abort() 方法终止ajax。
所以,你可以在离开路由的时候,调用 xhr 的 abort

然后ajax,回掉里面处理下。

    xhr.onreadystatechange = function(){
        if(request.readyState !==4) continue;// 忽略未完成的请求
        if(request.status === 200){} // 成功
    }
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏