TS封装axios并约束请求参数以及响应的类型

封装一个简单的axios

src/utils/axiosInstance.ts:其中定义了基本返回数据的类型

import axios, {AxiosInstance,AxiosResponse,AxiosError,AxiosRequestConfig,
} from "axios"// 定义基本返回数据类型
export interface ApiResponse<T> {code: numberdata: Tmsg: string
}// 创建 Axios 实例
const axiosInstance: AxiosInstance = axios.create({baseURL: import.meta.env.VITE_APP_BASE_API as string, // 基地址timeout: 5000, // 设置超时时间为 5 秒
})// 请求拦截器
axiosInstance.interceptors.request.use((config: AxiosRequestConfig) => {// ...return config},(error: AxiosError) => {// 对请求错误做些什么return Promise.reject(error)}
)// 响应拦截器
axiosInstance.interceptors.response.use((response: AxiosResponse) => {// ...return response},(error: AxiosError) => {// 对响应错误做些什么return Promise.reject(error)}
)
export default axiosInstance

src/utils/http.ts :声明get和post方法

import { AxiosRequestConfig } from "axios"
import axiosInstance, { ApiResponse } from "./axiosInstance"function get<T>(url: string, params?: {}): Promise<ApiResponse<T>> {return axiosInstance.get(url, { params })
}const post = <T>(url: string,data?: {},config?: AxiosRequestConfig
): Promise<T> => {return axiosInstance.post(url, data, { ...config })
}export { get, post }

声明请求参数以及响应数据的类型

在src下创建目录,结构如下:types下存放请求参数返回值类型

在这里插入图片描述

params.ts:约束请求参数类型

// 请求参数类型声明 --- api/index.tsx使用
export interface PLogin {passtoken: stringutoken: stringappkey: stringpwd: string
}

response.ts:约束响应数据类型

import { ApiResponse } from "@/utils/http/axiosInstance"
// 修改ApiResponse中data的类型
export type RLogin = ApiResponse<{ token: string }>

index.ts

import { PLogin } from "./types/params"
import { RLogin } from "./types/response"import { get, post } from "@/utils/http"const API = {login: (params: PLogin) => post<RLogin>("/login", params),
}export default API

使用

import API from "@/api"
API.login(values).then(res=>{},err=>{}) 

参数类型约束

在这里插入图片描述

返回值类型约束

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/600800.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS:如何安全且优雅地操控数组元素

前言 在 iOS 开发的世界里&#xff0c;数组(Array)的操作频率高得令人咋舌。数组贯穿于我们每一个功能的实现和每一行代码的编写之中&#xff0c;一手托起了数据结构的半边天。但这位工具之王&#xff0c;有时候也会变身为导致程序崩溃的罪魁祸首。当访问越界&#xff0c;当插…

如何批量替换文件名中的字符?汇总3个超简单办法

如何批量替换文件名中的字符&#xff1f;在现代社会中&#xff0c;我们的生活充斥着大量的数字化文件&#xff0c;如照片、文档、音频和视频等。然而&#xff0c;有时这些文件的命名可能并不理想&#xff0c;包含了不必要的字符或格式。这时&#xff0c;批量替换文件名中的字符…

MySQL 主从 AUTO_INCREMENT 不一致问题分析

本文介绍了 MySQL5.7 中常见的replace into 操作造成的主从auto_increment不一致现象&#xff0c;一旦触发了主从切换&#xff0c;业务的正常插入操作会触发主键冲突的报错提示。 一、问题描述 1.1 问题现象 在 MySQL 5.7 版本中&#xff0c;REPLACE INTO 操作在表存在自增主键…

基于javassm实现的旅游景点线路网站

开发语言&#xff1a;Java 框架&#xff1a;ssm 技术&#xff1a;JSP JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.3.…

【CVE复现计划】CVE-2024-0195

CVE-2024-0195 简介&#xff1a; SpiderFlow是新一代开源爬虫平台&#xff0c;以图形化方式定义爬虫流程&#xff0c;不写代码即可完成爬虫。基于springbootlayui开发的前后端不分离,也可以进行二次开发。该系统/function/save接口存在RCE漏洞&#xff0c;攻击者可以构造恶意命…

【大功率汽车大灯升压方案】LED恒流驱动芯片FP7208升压车灯调光应用,PWM内部转模拟,调光深度1%,无频闪顾虑,低亮无抖动

宝马X5前中排座椅宽大舒适&#xff0c;车厢内储物空间丰富。操控性能极佳&#xff0c;底盘稳扎精良。原车为氙气灯&#xff0c;其实宝马的氙气大灯配的比其他车型要好&#xff0c;照明效果是没得说的。但是不管什么灯久了都会出现光衰的情况。下面这辆宝马X5车灯已老化严重。 宝…

Jmeter ServerAgent windows启动报错 NoClassDefFoundError

下载ServerAgent-2.2.3 后执行startAgent.bat 报错如下&#xff1a; 尝试解决方案一&#xff1a; 将整个ServerAgent-2.2.3文件夹复制到jdk目录下的bin目录下&#xff0c;然后重新进入目录执行startAgent.bat

MySQL如何创建存储过程

工作中有时候需要自己去创建存储过程&#xff0c;然后调用存储去获得一些数据等&#xff0c;接下来就给大家介绍下MySQL如何创建存储过程。 语法&#xff1a; CREATE PROCEDURE 存储程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名 数据类型…]]) [特性 …] 过…

python 如何生成uuid

UUID&#xff08;Universally Unique Identifier&#xff09;是通用唯一识别码&#xff0c;在许多领域用作标识&#xff0c;比如我们常用的数据库也可以用它来作为主键&#xff0c;原理上它是可以对任何东西进行唯一的编码的。作为新手一看到类似varchar(40)这样的主键就觉得有…

西圣、漫步者、万魔开放式耳机怎么样?无广真实测评对比推荐

开放式耳机因其独特的音质体验和佩戴舒适度&#xff0c;受到了越来越多消费者的青睐。西圣、漫步者、万魔作为国内知名的耳机品牌&#xff0c;各自都推出了自家的开放式耳机产品&#xff0c;那么&#xff0c;这三款耳机究竟如何呢&#xff1f;身为开放式耳机党的我&#xff0c;…

python开发poc2,爆破脚本

#本课知识点和目的&#xff1a; ---协议模块使用&#xff0c;Request 爬虫技术&#xff0c;简易多线程技术&#xff0c;编码技术&#xff0c;Bypass 后门技术 下载ftp服务器模拟器 https://lcba.lanzouy.com/iAMePxl378h 随便创建一个账户&#xff0c;然后登录进去把ip改成…

RuleEngine规则引擎底层改造AviatorScript 之函数执行

https://gitee.com/aizuda/rule-engine-open 需求&#xff1a;使用上述开源框架进行改造&#xff0c;底层更换成AviatorScript &#xff0c;函数实现改造。 原本实现方式 Overridepublic Object run(ExecuteFunctionRequest executeTestRequest) {Integer functionId executeT…