??頁面發(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);
});