ホームページ >ウェブフロントエンド >jsチュートリアル >ページ切り替え時のvue+axios割り込みリクエストの実装方法
今回は、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 があるため、それを統一します)。 ;
以下はroutingスイッチングリッスンルータに置かれているリクエストの中断メソッドですbeforeそれぞれ、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(); });
コールポスト
<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 中国語 Web サイトの他の関連記事に注目してください。 推奨読書:
以上がページ切り替え時のvue+axios割り込みリクエストの実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。