request.js

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)
最后編輯于
?著作權(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ù)。

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

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