2023-07-06 20:59:22 +08:00
|
|
|
|
import request from './request';
|
2024-01-05 12:09:12 +08:00
|
|
|
|
import { useApiFetch } from '@/hooks/useRequest';
|
2021-06-07 17:22:07 +08:00
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 可用于各模块定义各自api请求
|
|
|
|
|
|
*/
|
|
|
|
|
|
class Api {
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 请求url
|
|
|
|
|
|
*/
|
|
|
|
|
|
url: string;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 请求方法
|
|
|
|
|
|
*/
|
|
|
|
|
|
method: string;
|
|
|
|
|
|
|
2023-12-06 09:23:23 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 请求前处理函数
|
|
|
|
|
|
* param1: param请求参数
|
|
|
|
|
|
*/
|
|
|
|
|
|
beforeHandler: Function;
|
|
|
|
|
|
|
2021-06-07 17:22:07 +08:00
|
|
|
|
constructor(url: string, method: string) {
|
|
|
|
|
|
this.url = url;
|
|
|
|
|
|
this.method = method;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-12-06 09:23:23 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 设置请求前处理回调函数
|
|
|
|
|
|
* @param func 请求前处理器
|
|
|
|
|
|
* @returns this
|
|
|
|
|
|
*/
|
|
|
|
|
|
withBeforeHandler(func: Function) {
|
|
|
|
|
|
this.beforeHandler = func;
|
|
|
|
|
|
return this;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-06-07 17:22:07 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 获取权限的完整url
|
|
|
|
|
|
*/
|
|
|
|
|
|
getUrl() {
|
|
|
|
|
|
return request.getApiUrl(this.url);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2023-12-11 01:00:09 +08:00
|
|
|
|
* 响应式使用该api
|
|
|
|
|
|
* @param params 响应式params
|
|
|
|
|
|
* @param reqOptions 其他可选值
|
|
|
|
|
|
* @returns
|
2021-06-07 17:22:07 +08:00
|
|
|
|
*/
|
2023-12-11 01:00:09 +08:00
|
|
|
|
useApi<T>(params: any = null, reqOptions: RequestInit = {}) {
|
|
|
|
|
|
return useApiFetch<T>(this, params, reqOptions);
|
2021-06-07 17:22:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2023-12-07 01:07:34 +08:00
|
|
|
|
/**
|
2023-12-11 01:00:09 +08:00
|
|
|
|
* fetch 请求对应的该api
|
2023-12-07 01:07:34 +08:00
|
|
|
|
* @param {Object} param 请求该api的参数
|
|
|
|
|
|
*/
|
2023-12-11 01:00:09 +08:00
|
|
|
|
async request(param: any = null, options: any = {}): Promise<any> {
|
|
|
|
|
|
const { execute, data } = this.useApi(param, options);
|
|
|
|
|
|
await execute();
|
|
|
|
|
|
return data.value;
|
2023-12-07 01:07:34 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2023-12-11 01:00:09 +08:00
|
|
|
|
* xhr 请求对应的该api
|
|
|
|
|
|
* @param {Object} param 请求该api的参数
|
2023-12-07 01:07:34 +08:00
|
|
|
|
*/
|
2023-12-11 01:00:09 +08:00
|
|
|
|
async xhrReq(param: any = null, options: any = {}): Promise<any> {
|
|
|
|
|
|
if (this.beforeHandler) {
|
|
|
|
|
|
this.beforeHandler(param);
|
2023-12-07 01:07:34 +08:00
|
|
|
|
}
|
2023-12-11 01:00:09 +08:00
|
|
|
|
return request.xhrReq(this.method, this.url, param, options);
|
2023-12-07 01:07:34 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2023-12-11 01:00:09 +08:00
|
|
|
|
/** 静态方法 **/
|
2023-12-07 01:07:34 +08:00
|
|
|
|
|
2021-06-07 17:22:07 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 静态工厂,返回Api对象,并设置url与method属性
|
|
|
|
|
|
* @param url url
|
|
|
|
|
|
* @param method 请求方法(get,post,put,delete...)
|
|
|
|
|
|
*/
|
2023-07-06 20:59:22 +08:00
|
|
|
|
static create(url: string, method: string): Api {
|
2021-06-07 17:22:07 +08:00
|
|
|
|
return new Api(url, method);
|
|
|
|
|
|
}
|
2023-04-13 20:11:22 +08:00
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 创建get api
|
|
|
|
|
|
* @param url url
|
|
|
|
|
|
*/
|
|
|
|
|
|
static newGet(url: string): Api {
|
|
|
|
|
|
return Api.create(url, 'get');
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* new post api
|
|
|
|
|
|
* @param url url
|
|
|
|
|
|
*/
|
|
|
|
|
|
static newPost(url: string): Api {
|
|
|
|
|
|
return Api.create(url, 'post');
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* new put api
|
|
|
|
|
|
* @param url url
|
|
|
|
|
|
*/
|
|
|
|
|
|
static newPut(url: string): Api {
|
|
|
|
|
|
return Api.create(url, 'put');
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* new delete api
|
|
|
|
|
|
* @param url url
|
|
|
|
|
|
*/
|
|
|
|
|
|
static newDelete(url: string): Api {
|
|
|
|
|
|
return Api.create(url, 'delete');
|
|
|
|
|
|
}
|
2021-06-07 17:22:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2023-07-06 20:59:22 +08:00
|
|
|
|
export default Api;
|
2023-12-11 01:00:09 +08:00
|
|
|
|
|
|
|
|
|
|
export class PageRes {
|
|
|
|
|
|
list: any[] = [];
|
|
|
|
|
|
total: number = 0;
|
|
|
|
|
|
}
|