axios攔截器

??頁面發(fā)送http請(qǐng)求,很多情況我們要對(duì)請(qǐng)求和其響應(yīng)進(jìn)行特定的處理;如果請(qǐng)求數(shù)非常多,單獨(dú)對(duì)每一個(gè)請(qǐng)求進(jìn)行處理會(huì)變得非常麻煩,程序的優(yōu)雅性也會(huì)大打折扣。好在強(qiáng)大的axios為開發(fā)者提供了這樣一個(gè)API:攔截器。攔截器分為 請(qǐng)求(request)攔截器和 響應(yīng)(response)攔截器。

1、請(qǐng)求攔截器

發(fā)送請(qǐng)求前統(tǒng)一處理,如:設(shè)置請(qǐng)求頭headers、應(yīng)用的版本號(hào)、終端類型等,用法如下:

axios.interceptors.request.use(
    config => {
        //do something like this
        config.headers.common['X-APP-SOURCE'] = "h5";
        config.headers.common['X-APP-VERSION'] = "1.4.5";
        return config
    },
    err => {
        return Promise.reject(err)
    })

2、響應(yīng)攔截器

有時(shí)候我們要根據(jù)響應(yīng)的狀態(tài)碼來進(jìn)行下一步操作,例如:由于當(dāng)前的token過期,接口返回401未授權(quán),那我們就要進(jìn)行重新登錄的操作,用法如下:

axios.interceptors.response.use(function(res){
    //do something like this
    switch (res.data.code) {
       case 401:  router.push({path: '/login'});
       ......
    }
    return res;
},function(err){
    return Promise.reject(err);
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容