refactor: axios

pull/12/head
xingyu 2023-05-14 17:20:03 +08:00
parent 855c705f32
commit f533aa58c7
3 changed files with 44 additions and 42 deletions

View File

@ -76,7 +76,10 @@ export class VAxios {
* @description: Interceptor configuration * @description: Interceptor configuration
*/ */
private setupInterceptors() { private setupInterceptors() {
const transform = this.getTransform() const {
axiosInstance,
options: { transform }
} = this
if (!transform) { if (!transform) {
return return
} }
@ -86,12 +89,11 @@ export class VAxios {
// 请求拦截器配置处理 // 请求拦截器配置处理
this.axiosInstance.interceptors.request.use((config: InternalAxiosRequestConfig) => { this.axiosInstance.interceptors.request.use((config: InternalAxiosRequestConfig) => {
// 如果开启取消重复请求,则禁止取消重复请求 const { requestOptions } = this.options
// @ts-ignore const ignoreCancelToken = requestOptions?.ignoreCancelToken ?? true
const { ignoreCancelToken } = config.requestOptions
const ignoreCancel = ignoreCancelToken !== undefined ? ignoreCancelToken : this.options.requestOptions?.ignoreCancelToken !ignoreCancelToken && axiosCanceler.addPending(config)
!ignoreCancel && axiosCanceler.addPending(config)
if (requestInterceptors && isFunction(requestInterceptors)) { if (requestInterceptors && isFunction(requestInterceptors)) {
config = requestInterceptors(config, this.options) config = requestInterceptors(config, this.options)
} }
@ -157,8 +159,7 @@ export class VAxios {
responseInterceptorsCatch && responseInterceptorsCatch &&
isFunction(responseInterceptorsCatch) && isFunction(responseInterceptorsCatch) &&
this.axiosInstance.interceptors.response.use(undefined, (error) => { this.axiosInstance.interceptors.response.use(undefined, (error) => {
// @ts-ignore return responseInterceptorsCatch(axiosInstance, error)
return responseInterceptorsCatch(this.axiosInstance, error)
}) })
} }

View File

@ -1,59 +1,60 @@
import type { InternalAxiosRequestConfig, Canceler } from 'axios' import type { AxiosRequestConfig } from 'axios'
import axios from 'axios'
import { isFunction } from '@/utils/is'
// Used to store the identification and cancellation function of each request // 用于存储每个请求的标识和取消函数
let pendingMap = new Map<string, Canceler>() const pendingMap = new Map<string, AbortController>()
export const getPendingUrl = (config: InternalAxiosRequestConfig) => [config.method, config.url].join('&') const getPendingUrl = (config: AxiosRequestConfig): string => {
return [config.method, config.url].join('&')
}
export class AxiosCanceler { export class AxiosCanceler {
/** /**
* *
* @param {Object} config * @param config
*/ */
addPending(config: InternalAxiosRequestConfig) { public addPending(config: AxiosRequestConfig): void {
this.removePending(config) this.removePending(config)
const url = getPendingUrl(config) const url = getPendingUrl(config)
config.cancelToken = const controller = new AbortController()
config.cancelToken || config.signal = config.signal || controller.signal
new axios.CancelToken((cancel) => {
if (!pendingMap.has(url)) { if (!pendingMap.has(url)) {
// 如果当前没有待处理的请求,添加它 // 如果当前请求不在等待中,将其添加到等待中
pendingMap.set(url, cancel) pendingMap.set(url, controller)
} }
})
} }
/** /**
* @description: *
*/ */
removeAllPending() { public removeAllPending(): void {
pendingMap.forEach((cancel) => { pendingMap.forEach((abortController) => {
cancel && isFunction(cancel) && cancel() if (abortController) {
abortController.abort()
}
}) })
pendingMap.clear() this.reset()
} }
/** /**
* *
* @param {Object} config * @param config
*/ */
removePending(config: InternalAxiosRequestConfig) { public removePending(config: AxiosRequestConfig): void {
const url = getPendingUrl(config) const url = getPendingUrl(config)
if (pendingMap.has(url)) { if (pendingMap.has(url)) {
// 如果有当前请求标识符处于pending状态则需要取消当前请求并移除 // 如果当前请求在等待中,取消它并将其从等待中移除
const cancel = pendingMap.get(url) const abortController = pendingMap.get(url)
cancel && cancel(url) if (abortController) {
abortController.abort(url)
}
pendingMap.delete(url) pendingMap.delete(url)
} }
} }
/** /**
* @description: reset *
*/ */
reset(): void { public reset(): void {
pendingMap = new Map<string, Canceler>() pendingMap.clear()
} }
} }

View File

@ -1,7 +1,7 @@
/** /**
* Data processing class, can be configured according to the project * Data processing class, can be configured according to the project
*/ */
import type { InternalAxiosRequestConfig, AxiosResponse, AxiosRequestConfig } from 'axios' import type { AxiosInstance, AxiosRequestConfig, AxiosResponse, InternalAxiosRequestConfig } from 'axios'
import type { RequestOptions, Result } from '@/types/axios' import type { RequestOptions, Result } from '@/types/axios'
export interface CreateAxiosOptions extends AxiosRequestConfig { export interface CreateAxiosOptions extends AxiosRequestConfig {
@ -12,7 +12,7 @@ export interface CreateAxiosOptions extends AxiosRequestConfig {
export abstract class AxiosTransform { export abstract class AxiosTransform {
/** /**
* @description: * @description:
*/ */
beforeRequestHook?: (config: AxiosRequestConfig, options: RequestOptions) => AxiosRequestConfig beforeRequestHook?: (config: AxiosRequestConfig, options: RequestOptions) => AxiosRequestConfig
@ -44,5 +44,5 @@ export abstract class AxiosTransform {
/** /**
* @description: * @description:
*/ */
responseInterceptorsCatch?: (axiosInstance: AxiosResponse, error: Error) => void responseInterceptorsCatch?: (axiosInstance: AxiosInstance, error: Error) => void
} }