ts封装axios

582 阅读1分钟

T封装axios

import axios from 'axios'
import type { AxiosInstance, AxiosRequestConfig, AxiosResponse } from 'axios'
// import { ElLoading } from 'element-plus'
// import { ILoadingInstance } from 'element-plus/lib/el-loading/src/loading.type'
interface TRequestInterceptors<T = AxiosResponse> {
  requestInterceptor?: (config: AxiosRequestConfig) => AxiosRequestConfig
  requestInterceptorCache?: (error: any) => any
  responseInterceptor?: (res: T) => T
  responseInterceptorCache?: (error: any) => any
}

// 为了扩展requestInterceptors
interface TRequestConfig<T = AxiosResponse> extends AxiosRequestConfig {
  interceptors?: TRequestInterceptors<T>
}

class TRequest {
  instance: AxiosInstance
  interceptors?: TRequestInterceptors

  constructor(config: TRequestConfig) {
    this.instance = axios.create(config)
    this.interceptors = config.interceptors

    // 从config中取出的拦截器是从实例中取出的拦截器
    this.instance.interceptors.request.use(
      this.interceptors?.requestInterceptor,
      this.interceptors?.requestInterceptorCache
    )
    this.instance.interceptors.response.use(
      this.interceptors?.responseInterceptor,
      this.interceptors?.responseInterceptorCache
    )

    // 添加所有实例都共有的拦截器
    this.instance.interceptors.request.use(
      (config) => {
        console.log('所有的实例都有的拦截器:请求成功')
        // this.loading = ElLoading.service({
        //   lock: true,
        //   text: '正在加载中。。。',
        //   background: 'rgba(0, 0, 0, 0.5)'
        // })
        return config.data
      },
      (err) => {
        console.log('所有的实例都有的拦截器:请求失败')
        return err
      }
    )
    this.instance.interceptors.response.use(
      (res) => {
        console.log('所有的实例都有的拦截器:响应成功')
        return res.data
      },
      (err) => {
        console.log('所有的实例都有的拦截器:响应失败')
        return err
      }
    )
  }

  // 单独传的拦截器
  request<T>(config: TRequestConfig<T>): Promise<T> {
    return new Promise((resolve, reject) => {
      if (config.interceptors?.requestInterceptor) {
        config = config.interceptors.requestInterceptor(config)
      }
      this.instance
        .request<any, T>(config)
        .then((res) => {
          if (config.interceptors?.responseInterceptor) {
            res = config.interceptors.responseInterceptor(res)
          }
          resolve(res)
        })
        .catch((err) => {
          reject(err)
        })
    })
  }
  get<T>(config: TRequestConfig<T>): Promise<T> {
    return this.request({ ...config, method: 'GET' })
  }
  post<T>(config: TRequestConfig<T>): Promise<T> {
    return this.request({ ...config, method: 'POST' })
  }
  patch<T>(config: TRequestConfig<T>): Promise<T> {
    return this.request({ ...config, method: 'PATCH' })
  }
  delete<T>(config: TRequestConfig<T>): Promise<T> {
    return this.request({ ...config, method: 'DELETE' })
  }
}

export default TRequest