perf: imporve axios logic

This commit is contained in:
Vben 2021-02-26 22:45:36 +08:00
parent 7c2f851692
commit a821d9a3a2
13 changed files with 77 additions and 74 deletions

View File

@ -1,14 +1,12 @@
import { defHttp } from '/@/utils/http/axios'; import { defHttp } from '/@/utils/http/axios';
import { GetAccountInfoModel } from './model/accountModel'; import { GetAccountInfoModel } from './model/accountModel';
const { get } = defHttp;
enum Api { enum Api {
ACCOUNT_INFO = '/account/getAccountInfo', ACCOUNT_INFO = '/account/getAccountInfo',
} }
// Get personal center-basic settings // Get personal center-basic settings
export function accountInfoApi() {
return defHttp.request<GetAccountInfoModel>({ export const accountInfoApi = () => get<GetAccountInfoModel>({ url: Api.ACCOUNT_INFO });
url: Api.ACCOUNT_INFO,
method: 'GET',
});
}

View File

@ -1,5 +1,7 @@
import { defHttp } from '/@/utils/http/axios'; import { defHttp } from '/@/utils/http/axios';
const { get } = defHttp;
enum Api { enum Api {
// The address does not exist // The address does not exist
Error = '/error', Error = '/error',
@ -8,9 +10,5 @@ enum Api {
/** /**
* @description: Trigger ajax error * @description: Trigger ajax error
*/ */
export function fireErrorApi() {
return defHttp.request({ export const fireErrorApi = () => get({ url: Api.Error });
url: Api.Error,
method: 'GET',
});
}

View File

@ -1,5 +1,6 @@
import { defHttp } from '/@/utils/http/axios'; import { defHttp } from '/@/utils/http/axios';
import { DemoOptionsGetResultModel } from './model/optionsModel'; import { DemoOptionsGetResultModel } from './model/optionsModel';
const { get } = defHttp;
enum Api { enum Api {
OPTIONS_LIST = '/select/getDemoOptions', OPTIONS_LIST = '/select/getDemoOptions',
@ -8,9 +9,4 @@ enum Api {
/** /**
* @description: Get sample options value * @description: Get sample options value
*/ */
export function optionsListApi() { export const optionsListApi = () => get<DemoOptionsGetResultModel>({ url: Api.OPTIONS_LIST });
return defHttp.request<DemoOptionsGetResultModel>({
url: Api.OPTIONS_LIST,
method: 'GET',
});
}

View File

@ -1,6 +1,8 @@
import { defHttp } from '/@/utils/http/axios'; import { defHttp } from '/@/utils/http/axios';
import { DemoParams, DemoListGetResultModel } from './model/tableModel'; import { DemoParams, DemoListGetResultModel } from './model/tableModel';
const { get } = defHttp;
enum Api { enum Api {
DEMO_LIST = '/table/getDemoList', DEMO_LIST = '/table/getDemoList',
} }
@ -8,13 +10,12 @@ enum Api {
/** /**
* @description: Get sample list value * @description: Get sample list value
*/ */
export function demoListApi(params: DemoParams) {
return defHttp.request<DemoListGetResultModel>({ export const demoListApi = (params: DemoParams) =>
get<DemoListGetResultModel>({
url: Api.DEMO_LIST, url: Api.DEMO_LIST,
method: 'GET',
params, params,
headers: { headers: {
ignoreCancelToken: true, ignoreCancelToken: true,
}, },
}); });
}

View File

@ -1,7 +1,8 @@
import { defHttp } from '/@/utils/http/axios'; import { defHttp } from '/@/utils/http/axios';
import { getMenuListByIdParams, getMenuListByIdParamsResultModel } from './model/menuModel'; import { getMenuListByIdParams, getMenuListByIdParamsResultModel } from './model/menuModel';
const { get } = defHttp;
enum Api { enum Api {
GetMenuListById = '/getMenuListById', GetMenuListById = '/getMenuListById',
} }
@ -9,10 +10,7 @@ enum Api {
/** /**
* @description: Get user menu based on id * @description: Get user menu based on id
*/ */
export function getMenuListById(params: getMenuListByIdParams) {
return defHttp.request<getMenuListByIdParamsResultModel>({ export const getMenuListById = (params: getMenuListByIdParams) => {
url: Api.GetMenuListById, return get<getMenuListByIdParamsResultModel>({ url: Api.GetMenuListById, params });
method: 'GET', };
params,
});
}

View File

@ -7,6 +7,7 @@ import {
} from './model/userModel'; } from './model/userModel';
import { ErrorMessageMode } from '/@/utils/http/axios/types'; import { ErrorMessageMode } from '/@/utils/http/axios/types';
const { post, get } = defHttp;
enum Api { enum Api {
Login = '/login', Login = '/login',
GetUserInfoById = '/getUserInfoById', GetUserInfoById = '/getUserInfoById',
@ -17,10 +18,9 @@ enum Api {
* @description: user login api * @description: user login api
*/ */
export function loginApi(params: LoginParams, mode: ErrorMessageMode = 'modal') { export function loginApi(params: LoginParams, mode: ErrorMessageMode = 'modal') {
return defHttp.request<LoginResultModel>( return post<LoginResultModel>(
{ {
url: Api.Login, url: Api.Login,
method: 'POST',
params, params,
}, },
{ {
@ -33,17 +33,15 @@ export function loginApi(params: LoginParams, mode: ErrorMessageMode = 'modal')
* @description: getUserInfoById * @description: getUserInfoById
*/ */
export function getUserInfoById(params: GetUserInfoByUserIdParams) { export function getUserInfoById(params: GetUserInfoByUserIdParams) {
return defHttp.request<GetUserInfoByUserIdModel>({ return get<GetUserInfoByUserIdModel>({
url: Api.GetUserInfoById, url: Api.GetUserInfoById,
method: 'GET',
params, params,
}); });
} }
export function getPermCodeByUserId(params: GetUserInfoByUserIdParams) { export function getPermCodeByUserId(params: GetUserInfoByUserIdParams) {
return defHttp.request<string[]>({ return get<string[]>({
url: Api.GetPermCodeByUserId, url: Api.GetPermCodeByUserId,
method: 'GET',
params, params,
}); });
} }

View File

@ -165,6 +165,22 @@ export class VAxios {
}; };
} }
get<T = any>(config: AxiosRequestConfig, options?: RequestOptions): Promise<T> {
return this.request({ ...config, method: 'GET' }, options);
}
post<T = any>(config: AxiosRequestConfig, options?: RequestOptions): Promise<T> {
return this.request({ ...config, method: 'POST' }, options);
}
put<T = any>(config: AxiosRequestConfig, options?: RequestOptions): Promise<T> {
return this.request({ ...config, method: 'PUT' }, options);
}
delete<T = any>(config: AxiosRequestConfig, options?: RequestOptions): Promise<T> {
return this.request({ ...config, method: 'DELETE' }, options);
}
request<T = any>(config: AxiosRequestConfig, options?: RequestOptions): Promise<T> { request<T = any>(config: AxiosRequestConfig, options?: RequestOptions): Promise<T> {
let conf: AxiosRequestConfig = cloneDeep(config); let conf: AxiosRequestConfig = cloneDeep(config);
const transform = this.getTransform(); const transform = this.getTransform();
@ -173,7 +189,7 @@ export class VAxios {
const opt: RequestOptions = Object.assign({}, requestOptions, options); const opt: RequestOptions = Object.assign({}, requestOptions, options);
const { beforeRequestHook, requestCatch, transformRequestData } = transform || {}; const { beforeRequestHook, requestCatchHook, transformRequestHook } = transform || {};
if (beforeRequestHook && isFunction(beforeRequestHook)) { if (beforeRequestHook && isFunction(beforeRequestHook)) {
conf = beforeRequestHook(conf, opt); conf = beforeRequestHook(conf, opt);
} }
@ -183,16 +199,16 @@ export class VAxios {
this.axiosInstance this.axiosInstance
.request<any, AxiosResponse<Result>>(conf) .request<any, AxiosResponse<Result>>(conf)
.then((res: AxiosResponse<Result>) => { .then((res: AxiosResponse<Result>) => {
if (transformRequestData && isFunction(transformRequestData)) { if (transformRequestHook && isFunction(transformRequestHook)) {
const ret = transformRequestData(res, opt); const ret = transformRequestHook(res, opt);
ret !== errorResult ? resolve(ret) : reject(new Error('request error!')); ret !== errorResult ? resolve(ret) : reject(new Error('request error!'));
return; return;
} }
resolve((res as unknown) as Promise<T>); resolve((res as unknown) as Promise<T>);
}) })
.catch((e: Error) => { .catch((e: Error) => {
if (requestCatch && isFunction(requestCatch)) { if (requestCatchHook && isFunction(requestCatchHook)) {
reject(requestCatch(e)); reject(requestCatchHook(e));
return; return;
} }
reject(e); reject(e);

View File

@ -3,14 +3,14 @@ import axios from 'axios';
import { isFunction } from '/@/utils/is'; import { isFunction } from '/@/utils/is';
// 声明一个 Map 用于存储每个请求的标识 和 取消函数 // Used to store the identification and cancellation function of each request
let pendingMap = new Map<string, Canceler>(); let pendingMap = new Map<string, Canceler>();
export const getPendingUrl = (config: AxiosRequestConfig) => [config.method, config.url].join('&'); export const getPendingUrl = (config: AxiosRequestConfig) => [config.method, config.url].join('&');
export class AxiosCanceler { export class AxiosCanceler {
/** /**
* * Add request
* @param {Object} config * @param {Object} config
*/ */
addPending(config: AxiosRequestConfig) { addPending(config: AxiosRequestConfig) {
@ -20,14 +20,14 @@ export class AxiosCanceler {
config.cancelToken || config.cancelToken ||
new axios.CancelToken((cancel) => { new axios.CancelToken((cancel) => {
if (!pendingMap.has(url)) { if (!pendingMap.has(url)) {
// 如果 pending 中不存在当前请求,则添加进去 // If there is no current request in pending, add it
pendingMap.set(url, cancel); pendingMap.set(url, cancel);
} }
}); });
} }
/** /**
* @description: pending * @description: Clear all pending
*/ */
removeAllPending() { removeAllPending() {
pendingMap.forEach((cancel) => { pendingMap.forEach((cancel) => {
@ -37,14 +37,15 @@ export class AxiosCanceler {
} }
/** /**
* * Removal request
* @param {Object} config * @param {Object} config
*/ */
removePending(config: AxiosRequestConfig) { removePending(config: AxiosRequestConfig) {
const url = getPendingUrl(config); const url = getPendingUrl(config);
if (pendingMap.has(url)) { if (pendingMap.has(url)) {
// 如果在 pending 中存在当前请求标识,需要取消当前请求,并且移除 // If there is a current request identifier in pending,
// the current request needs to be cancelled and removed
const cancel = pendingMap.get(url); const cancel = pendingMap.get(url);
cancel && cancel(url); cancel && cancel(url);
pendingMap.delete(url); pendingMap.delete(url);
@ -52,7 +53,7 @@ export class AxiosCanceler {
} }
/** /**
* @description: * @description: reset
*/ */
reset(): void { reset(): void {
pendingMap = new Map<string, Canceler>(); pendingMap = new Map<string, Canceler>();

View File

@ -1,25 +1,25 @@
/** /**
* * Data processing class, can be configured according to the project
*/ */
import type { AxiosRequestConfig, AxiosResponse } from 'axios'; import type { AxiosRequestConfig, AxiosResponse } from 'axios';
import type { RequestOptions, Result } from './types'; import type { RequestOptions, Result } from './types';
export abstract class AxiosTransform { export abstract class AxiosTransform {
/** /**
* @description: * @description: Process configuration before request
* @description: Process configuration before request * @description: Process configuration before request
*/ */
beforeRequestHook?: (config: AxiosRequestConfig, options: RequestOptions) => AxiosRequestConfig; beforeRequestHook?: (config: AxiosRequestConfig, options: RequestOptions) => AxiosRequestConfig;
/** /**
* @description: * @description: Request successfully processed
*/ */
transformRequestData?: (res: AxiosResponse<Result>, options: RequestOptions) => any; transformRequestHook?: (res: AxiosResponse<Result>, options: RequestOptions) => any;
/** /**
* @description: * @description:
*/ */
requestCatch?: (e: Error) => Promise<any>; requestCatchHook?: (e: Error) => Promise<any>;
/** /**
* @description: * @description:

View File

@ -1,2 +1,2 @@
// 接口返回值data不能为这个否则会判为请求失败 // The interface return value data cannot be this, otherwise the request will be judged as a failure
export const errorResult = '__ERROR_RESULT__'; export const errorResult = '__ERROR_RESULT__';

View File

@ -13,15 +13,12 @@ export function createNow(join: boolean, restful = false): string | object {
if (restful) { if (restful) {
return `?_t=${now}`; return `?_t=${now}`;
} }
return { _t: now };
return {
_t: now,
};
} }
const DATE_TIME_FORMAT = 'YYYY-MM-DD HH:mm'; const DATE_TIME_FORMAT = 'YYYY-MM-DD HH:mm';
/** /**
* @description: * @description: Format request parameter time
*/ */
export function formatRequestDate(params: any) { export function formatRequestDate(params: any) {
for (const key in params) { for (const key in params) {

View File

@ -32,7 +32,7 @@ const transform: AxiosTransform = {
/** /**
* @description: * @description:
*/ */
transformRequestData: (res: AxiosResponse<Result>, options: RequestOptions) => { transformRequestHook: (res: AxiosResponse<Result>, options: RequestOptions) => {
const { t } = useI18n(); const { t } = useI18n();
const { isTransformRequestResult } = options; const { isTransformRequestResult } = options;
// 不进行任何处理,直接返回 // 不进行任何处理,直接返回

View File

@ -1,22 +1,21 @@
import type { AxiosRequestConfig } from 'axios'; import type { AxiosRequestConfig } from 'axios';
import { AxiosTransform } from './axiosTransform'; import type { AxiosTransform } from './axiosTransform';
export type ErrorMessageMode = 'none' | 'modal' | 'message' | undefined; export type ErrorMessageMode = 'none' | 'modal' | 'message' | undefined;
export interface RequestOptions { export interface RequestOptions {
// 请求参数拼接到url // Splicing request parameters to url
joinParamsToUrl?: boolean; joinParamsToUrl?: boolean;
// 格式化请求参数时间 // Format request parameter time
formatDate?: boolean; formatDate?: boolean;
// 是否处理请求结果 // Whether to process the request result
isTransformRequestResult?: boolean; isTransformRequestResult?: boolean;
// 是否加入url // Whether to join url
joinPrefix?: boolean; joinPrefix?: boolean;
// 接口地址, 不填则使用默认apiUrl // Interface address, use the default apiUrl if you leave it blank
apiUrl?: string; apiUrl?: string;
// 错误消息提示类型 // Error message prompt type
errorMessageMode?: ErrorMessageMode; errorMessageMode?: ErrorMessageMode;
// 是否加入时间戳 // Whether to add a timestamp
joinTime?: boolean; joinTime?: boolean;
} }
@ -32,15 +31,16 @@ export interface Result<T = any> {
message: string; message: string;
result: T; result: T;
} }
// multipart/form-data上传文件
// multipart/form-data: upload file
export interface UploadFileParams { export interface UploadFileParams {
// 其他参数 // Other parameters
data?: Indexable; data?: Indexable;
// 文件参数的接口字段名 // File parameter interface field name
name?: string; name?: string;
// 文件 // file name
file: File | Blob; file: File | Blob;
// 文件名 // file name
filename?: string; filename?: string;
[key: string]: any; [key: string]: any;
} }