import axios ,{AxiosInstance,AxiosRequestConfig,AxiosResponse} from 'axios'
export class Request {
public static axiosInstance:AxiosInstance;
public static init() {
this.axiosInstance = axios.create({
baseURL:'/api',
timeOut:6000
});
// 初始化攔截器
this.initInterceptors();
return axios
}
// 初始化攔截器
public static initInterceptors() {
// 設(shè)置post請(qǐng)求頭
this.axiosInstance.defaults.headers.post['Content-Type'] = 'application/x-ww-form-urlencoded';
this.axiosInstance.interceptors.request.use(
(config:AxiosRequestConfig) => {
// 登錄流程控制中,根據(jù)本地是否存在token判斷用戶的登錄情況
const token = localStorage.getItem('ACCESS_TOKEN');
if(token){
config.headers.Authorization = 'Bearer' + token;
}
return config
},
(error) => {
console.log(error)
}
);
this.axiosInstance.interceptors.response.use(
(response:AxiosResponse) => {
if(response.status === 200){
return response;
}else {
Request.errorHandle(response);
return response
}
},
(error) => {
const {response} = error;
if(response){
Request.errorHandle(response);
return Promise.reject(response.data);
}else {
console.log("網(wǎng)絡(luò)連接異常,請(qǐng)稍后再試!")
}
}
)
};
public static errorHandle(res){
switch(res.status){
case 401:
break;
case 403:
break;
case 404:
break;
default:
console.log('報(bào)錯(cuò)了')
}
}
}
// 使用
// export function login (params) {
// return Request.axiosInstance({
// url:'/xxxxx',
// method:'post',
// data:params
// })
// }
//注:處理響應(yīng)數(shù)據(jù) (示例代碼,實(shí)際可直接直接使用await-to-js)
request.js
最后編輯于 :
?著作權(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),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 錯(cuò)誤信息如下: app.js:669 Uncaught Error: [??]: getActivePinia wa...
- 最近搭建template項(xiàng)目使用了axios用于接口請(qǐng)求,由于第一次自己搭建項(xiàng)目,遇到的坑比較多,原版也都是英文,...
- vue-element-template 如何使用官方request.js請(qǐng)求 許多新手在使用VUE-elemen...