有一个需求,通过JSON数据,第一层是对应的页面对象(比如是用户页面),第二层是该页面的API请求名(比如用户的增删改查),第三层是该API的配置信息(比如,method,url…这里主要跟你的封装有关)
const api_obj: IApiObj = {
// 登陆
loginPage: {
login: {
method: 'post',
url: '/server/login'
},
loginPc: {
method: 'post',
url: '/server/login/loginPc'
},
refresh: {
method: 'post',
url: '/server/login/refresh'
}
},
// ...
}
由此生成一个对应的AXIOS对象树,如下:
对象名不确定,可以通过字符串索引的形式
import type { AxiosRequestConfig, AxiosResponse } from 'axios'
export interface IHttp {
[key: string]: {
[key: string]: (
// 传递的Data
params?: IApi_objParams
) => Promise<AxiosResponse>
}
}