vue axios页面切换时怎么中断请求
程序员文章站
2022-04-18 09:51:51
...
这次给大家带来vue axios页面切换时怎么中断请求,vue axios页面切换时中断请求的注意事项有哪些,下面就是实战案例,一起来看一下。
如下所示:
Vue.prototype.$ajax=axios; const CancelToken = axios.CancelToken; let cancel; let cancelAjaxText = '中断成功'; Vue.prototype.post = function(url,data,loading){ var ajax = Vue.prototype.$ajax({ method: 'post', url:url, data: data, cancelToken: new CancelToken(c => { //强行中断请求要用到的 cancel = c }) }).then(res =>res.data,res=>{ //中断请求和请求出错都会走这里,我这里用 cancelAjaxText 来区别 if(res.message == cancelAjaxText){ return {status : false,msg:cancelAjaxText} }else{ this.$confirm('登录过时,是否重新登录', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning' }).then(() => { window.location.href = Vue.prototype.url_head + '/'; }).catch(() => { }); } }) return ajax; };
接入 axios ,在POST方法里加入 cancelToken 数据,在上面else中,中断请求和请求出错都会走那里,所以用一个msg来识别(因为接口返回中也有一个msg,统一一下);
以下是 中断请求的方法,放在 路由切换的监听 router.beforeEach 中 ,cancel 是中断的方法,在post 的 cancelToken 里面拿出来的
Vue.prototype.cancelAjax = function(){ //切换页面强行中断请求 router.beforeEach中用到 if(cancel){ cancel(cancelAjaxText); } }
router.beforeEach((to, from, next) => { <span style="white-space:pre;"> </span>Vue.prototype.cancelAjax() next(); });
调用post
<span style="white-space:pre;"> </span>this.post(this.ajaxUrl + 'getCrTree',{ devAddr : this.changeData.devAddr, innerId : this.changeData.innerId, }).then(ret=>{ if(ret.status){ }else{ this.msg(ret.msg); } })
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
以上就是vue axios页面切换时怎么中断请求的详细内容,更多请关注其它相关文章!
推荐阅读
-
使用vue-router切换页面时,获取上一页url以及当前页面url的方法
-
Vue 路由切换时页面内容没有重新加载的解决方法
-
详解使用vue-router进行页面切换时滚动条位置与滚动监听事件
-
Vue-router 切换组件页面时进入进出动画方法
-
Vue Spa切换页面时更改标题的实例代码
-
vue 获取页面详情后 切换页面时 如何监听用户是否修改过信息
-
Vue 路由切换时页面内容没有重新加载的解决方法
-
VUE怎么解决路由跳转时及跳转到外部链接,再返回的页面缓存问题
-
vue axios 在页面切换时中断请求方法 ajax
-
Vue用户进行页面切换(路由跳转)时,动态改变路由的动画(transition效果)