service.ts 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import axios, { AxiosError } from 'axios'
  2. import { defaultRequestInterceptors, defaultResponseInterceptors } from './config'
  3. import { AxiosInstance, InternalAxiosRequestConfig, RequestConfig, AxiosResponse } from './types'
  4. import { ElMessage } from 'element-plus'
  5. import { REQUEST_TIMEOUT } from '@/constants'
  6. export const PATH_URL = import.meta.env.VITE_API_BASE_PATH
  7. const abortControllerMap: Map<string, AbortController> = new Map()
  8. const axiosInstance: AxiosInstance = axios.create({
  9. timeout: REQUEST_TIMEOUT,
  10. baseURL: PATH_URL
  11. })
  12. axiosInstance.interceptors.request.use((res: InternalAxiosRequestConfig) => {
  13. const controller = new AbortController()
  14. const url = res.url || ''
  15. res.signal = controller.signal
  16. abortControllerMap.set(import.meta.env.VITE_USE_MOCK ? url.replace('/mock', '') : url, controller)
  17. return res
  18. })
  19. axiosInstance.interceptors.response.use(
  20. (res: AxiosResponse) => {
  21. const url = res.config.url || ''
  22. abortControllerMap.delete(url)
  23. // 这里不能做任何处理,否则后面的 interceptors 拿不到完整的上下文了
  24. return res
  25. },
  26. (error: AxiosError) => {
  27. console.log('err: ' + error) // for debug
  28. ElMessage.error(error.message)
  29. return Promise.reject(error)
  30. }
  31. )
  32. axiosInstance.interceptors.request.use(defaultRequestInterceptors)
  33. axiosInstance.interceptors.response.use(defaultResponseInterceptors)
  34. const service = {
  35. request: (config: RequestConfig) => {
  36. return new Promise((resolve, reject) => {
  37. if (config.interceptors?.requestInterceptors) {
  38. config = config.interceptors.requestInterceptors(config as any)
  39. }
  40. axiosInstance
  41. .request(config)
  42. .then((res) => {
  43. resolve(res)
  44. })
  45. .catch((err: any) => {
  46. reject(err)
  47. })
  48. })
  49. },
  50. cancelRequest: (url: string | string[]) => {
  51. const urlList = Array.isArray(url) ? url : [url]
  52. for (const _url of urlList) {
  53. abortControllerMap.get(_url)?.abort()
  54. abortControllerMap.delete(_url)
  55. }
  56. },
  57. cancelAllRequest() {
  58. for (const [_, controller] of abortControllerMap) {
  59. controller.abort()
  60. }
  61. abortControllerMap.clear()
  62. }
  63. }
  64. export default service