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

封装一个简单的axios

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

import axios, {
  AxiosInstance,
  AxiosResponse,
  AxiosError,
  AxiosRequestConfig,
} from "axios"

// 定义基本返回数据类型
export interface ApiResponse<T> {
  code: number
  data: T
  msg: 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: string
  utoken: string
  appkey: string
  pwd: 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=>{}) 

参数类型约束

在这里插入图片描述

返回值类型约束

在这里插入图片描述

相关推荐

  1. 封装全局axios请求

    2024-04-08 10:58:02       19 阅读
  2. uniapp+axios请求封装

    2024-04-08 10:58:02       10 阅读
  3. Vue3+Vite+Axios Request 请求封装TS版本)最新

    2024-04-08 10:58:02       21 阅读
  4. 请求封装axios、fetch)

    2024-04-08 10:58:02       35 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-08 10:58:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-08 10:58:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-08 10:58:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-08 10:58:02       20 阅读

热门阅读

  1. Windows DLL(动态链接库)的用处

    2024-04-08 10:58:02       19 阅读
  2. Spring Boot中整合Redis

    2024-04-08 10:58:02       17 阅读
  3. C#实践作业1(类、接口、委托)

    2024-04-08 10:58:02       12 阅读
  4. 动态规划算法 - LC354. 俄罗斯套娃信封问题

    2024-04-08 10:58:02       12 阅读
  5. Linux常用命令

    2024-04-08 10:58:02       12 阅读
  6. Scrapy数据存储到数据库

    2024-04-08 10:58:02       12 阅读
  7. 人到中年,IT从业者怎么办

    2024-04-08 10:58:02       12 阅读
  8. 猜测生日日期

    2024-04-08 10:58:02       15 阅读
  9. 正则表达式

    2024-04-08 10:58:02       12 阅读
  10. 基于Docker 快速搭建EFK日志中心

    2024-04-08 10:58:02       9 阅读
  11. 利用python抓取小说,爬虫抓取小说

    2024-04-08 10:58:02       12 阅读
  12. 关于APP分发,要取得更好效果需要注意的

    2024-04-08 10:58:02       12 阅读