이번에는 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에서는 인터럽트 요청 및 요청 오류가 해당 위치로 이동하므로 메시지를 사용하여 식별합니다. 인터페이스 반환 메시지도 있으니 통일해주세요);
다음은 리스닝 라우터에 배치된 요청을 중단하는 방법입니다. 각 라우팅 스위치가 취소되는 방법입니다. to Interrupt, 이는 게시물의 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(); });
Call 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); } })
이 기사의 사례를 읽은 후 방법을 마스터했다고 믿습니다. 더 흥미로운 정보를 보려면 다음을 주의하세요. php 중국어 홈페이지기타관련 기사!
추천 도서:
위 내용은 vue axios 페이지를 전환할 때 요청을 중단하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!