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


Posted in Javascript onMarch 05, 2018

如下所示:

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 在页面切换时中断请求方法 ajax就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
IE中createElement需要注意的一个问题
Jul 13 Javascript
js写的评论分页(还不错)
Dec 23 Javascript
基于编写jQuery的无缝滚动插件
Aug 02 Javascript
IE6-IE9中tbody的innerHTML不能赋值的解决方法
Sep 26 Javascript
jQuery中toggleClass()方法用法实例
Jan 05 Javascript
jQuery实现的在线答题功能
Apr 12 Javascript
JS更改select内option属性的方法
Oct 14 Javascript
JavaScript中对DOM节点的访问、创建、修改、删除
Nov 16 Javascript
原生javascript+css3编写的3D魔方动画旋扭特效
Mar 14 Javascript
Node批量爬取头条视频并保存方法
Sep 20 Javascript
vue如何截取字符串
May 06 Javascript
JS一次前端面试经历记录
Mar 19 Javascript
node.js通过axios实现网络请求的方法
Mar 05 #Javascript
axios发送post请求springMVC接收不到参数的解决方法
Mar 05 #Javascript
基于vue 添加axios组件,解决post传参数为null的问题
Mar 05 #Javascript
解决vue处理axios post请求传参的问题
Mar 05 #Javascript
解决vue2中使用axios http请求出现的问题
Mar 05 #Javascript
在vue项目中引入highcharts图表的方法(详解)
Mar 05 #Javascript
Angular @HostBinding()和@HostListener()用法
Mar 05 #Javascript
You might like
phpBB BBcode处理的漏洞
2006/10/09 PHP
PHP面向对象分析设计的61条军规小结
2010/07/17 PHP
解析phpstorm + xdebug 远程断点调试
2013/06/20 PHP
javascript 数组排序函数
2009/08/20 Javascript
javascript写的日历类(基于pj)
2010/12/28 Javascript
zShowBox 图片放大展示jquery版 兼容性
2011/09/24 Javascript
JavaScript中发布/订阅模式的简单实例
2014/11/05 Javascript
JavaScript模块化开发之SeaJS
2015/12/13 Javascript
BootStrap中按钮点击后被禁用按钮的最佳实现方法
2016/09/23 Javascript
Javascript 实现计算器时间功能详解及实例(二)
2017/01/08 Javascript
jQuery使用unlock.js插件实现滑动解锁
2017/04/04 jQuery
Laravel整合Bootstrap 4的完整方案(推荐)
2018/01/25 Javascript
ng-repeat指令在迭代对象时的去重方法
2018/10/02 Javascript
微信小程序scroll-view的滚动条设置实现
2020/03/02 Javascript
vue通过过滤器实现数据格式化
2020/07/20 Javascript
python实现斐波那契递归函数的方法
2014/09/08 Python
python字符串string的内置方法实例详解
2018/05/14 Python
浅谈pycharm出现卡顿的解决方法
2018/12/03 Python
pytorch索引查找 index_select的例子
2019/08/18 Python
Python环境Pillow( PIL )图像处理工具使用解析
2019/09/12 Python
Pyecharts 动态地图 geo()和map()的安装与用法详解
2020/03/25 Python
使用Pytorch搭建模型的步骤
2020/11/16 Python
Python 中如何使用 virtualenv 管理虚拟环境
2021/01/21 Python
墨尔本复古时尚品牌:Dangerfield
2018/12/12 全球购物
事业单位个人应聘自荐信
2013/09/21 职场文书
经典演讲稿范文
2013/12/30 职场文书
狼和鹿教学反思
2014/02/05 职场文书
《东方明珠》教学反思
2014/04/20 职场文书
综艺节目策划方案
2014/06/13 职场文书
会计系毕业求职信
2014/08/07 职场文书
银行党的群众路线教育实践活动对照检查材料
2014/09/25 职场文书
2014年学校总务处工作总结
2014/12/08 职场文书
同事欢送会致辞
2015/07/31 职场文书
会计专业自荐信范文
2019/05/22 职场文书
python基础学习之递归函数知识总结
2021/05/26 Python
Spring中bean的生命周期之getSingleton方法
2021/06/30 Java/Android