vue axios 在页面切换时中断请求 ajax

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  来区别
                        //注意:如果在切换下个页面的勾子created 就开始请求,这个请求会比这里跑得快,也就是在这里的前面
	        	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) => {
	Vue.prototype.cancelAjax()	
	next();	
});

调用post 

			this.post(this.ajaxUrl + 'getCrTree',{
				devAddr : this.changeData.devAddr,
				innerId : this.changeData.innerId,
			}).then(ret=>{
				if(ret.status){
					
				}else{
					this.msg(ret.msg);
				}
			})


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值