封裝axios統(tǒng)一http請(qǐng)求對(duì)象

http-clients

import axios, {AxiosInstance, AxiosResponse} from 'axios';

export abstract class HttpClient {
    protected readonly instance: AxiosInstance;

    protected constructor(baseURL: string) {
        this.instance = axios.create({
            baseURL,
            headers: {'Content-Type': 'application/json'},
        });

        this._initializeResponseInterceptor();
    }

    private _initializeResponseInterceptor = () => {
        this.instance.interceptors.response.use(
            this._handleResponse,
            this._handleError,
        );
    };

    private _handleResponse = (res: AxiosResponse) => res.data.data || res.data;

    protected _handleError = (error: any) => Promise.reject(error);
}

tags-http-client

import {HttpClient} from '../http-client';
import {Tag} from '../types';
import {AxiosRequestConfig} from "axios";

class TagsApi extends HttpClient {
    public constructor() {
        super('http://localhost:3000');

        this._initializeRequestInterceptor();
    }

    private _initializeRequestInterceptor = () => {
        this.instance.interceptors.request.use(
            this._handleRequest,
        );
    };

    private _handleRequest = (config: AxiosRequestConfig) => {
        config.headers['Authorization'] = 'Bearer ...';
        return config;
    };

    public getTags = (): Promise<any> => this.instance.get<Tag[]>('/tags');

}

export default TagsApi;
?著作權(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ù)。

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