// 獲取CancelToken
const CancelToken = axios.CancelToken;
const source = CancelToken.source();
// http request 攔截器);
axios.interceptors.request.use(
(config) => {
// 全局添加cancelToken
newConfig.cancelToken = source.token;
return newConfig;
},
(err) => {
const error = err;
return Promise.reject(error);
},
);
// http response 攔截器
axios.interceptors.response.use((response) => {
const code = response.data.code;
if (code == '002') {
// 某個請求的響應(yīng)滿足特定條件的情況下,取消其他正在進行的請求
source.cancel();
}
return Promise.resolve(response.data);
}, (error) => {
if (axios.isCancel(error)) { // 取消請求的情況下,終端Promise調(diào)用鏈
return new Promise(() => {});
} else {
return Promise.reject(error);
}
});
axios全局設(shè)置取消請求及中斷Promise調(diào)用鏈
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- Cover 在Vue中使用axios 這個老生常談了,還是先記錄一遍,方面后面自己查。 !!! 設(shè)置form-da...
- 現(xiàn)在應(yīng)該大部分公司都是前后端分離了。so,數(shù)據(jù)請求的封裝還是必須的。 為了實現(xiàn)向ios中block封裝請求的異步的...