>  기사  >  웹 프론트엔드  >  Vue에서는 페이지 전환 시 인터럽트 요청 방식을 구현하기 위해 axios를 사용합니다.

Vue에서는 페이지 전환 시 인터럽트 요청 방식을 구현하기 위해 axios를 사용합니다.

亚连
亚连원래의
2018-06-01 11:26:312123검색

이제 페이지 전환 시 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 来区别
	  	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에서는 인터럽트 요청 및 요청 오류가 해당 위치로 이동하므로 메시지를 사용하여 식별합니다(인터페이스가 있기 때문입니다). return 메시지도 있으니 통일하세요);

다음은 리스닝 라우터에 있는 요청을 중단하는 방법입니다. 각 라우팅 스위치 앞에 취소하는 것이 중단되는 방법입니다. 게시물의 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(); 
});

및 게시물

<span style="white-space:pre;">   </span>this.post(this.ajaxUrl + &#39;getCrTree&#39;,{ 
    devAddr : this.changeData.devAddr, 
    innerId : this.changeData.innerId, 
   }).then(ret=>{ 
    if(ret.status){ 
      
    }else{ 
     this.msg(ret.msg); 
    } 
   })

을 호출했습니다. 위 내용은 제가 모두를 위해 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

setTimeout 시간이 0으로 설정됨 상세 분석

JS

에서 구현한 집합 중복 제거, 교집합, 합집합 및 차이 집합 기능의 예 Bootstrap에서 데이터-[*] 속성 구성

위 내용은 Vue에서는 페이지 전환 시 인터럽트 요청 방식을 구현하기 위해 axios를 사용합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.