react+ ts vite搭建及二次封装请求的过程解析
更新时间:2023年04月23日 09:56:05 作者:——a
这篇文章主要介绍了react+ ts vite搭建及二次封装请求,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
1.搭建项目
npm create vite
2.下载axios
npm install axios
打开项目创建基本项目结构
3.创建http文件夹下index.ts
引入axios
import axios, { AxiosResponse, AxiosInstance, InternalAxiosRequestConfig, } from "axios";
重新创建axios
const instance: AxiosInstance = axios.create({ baseURL: // vite 环境变量判断 import.meta.env.MODE === "development" ? "/api" : import.meta.env.VITE_APP_BASE_URL, timeout: 10000, });
创建拦截器
instance.interceptors.request.use((config: InternalAxiosRequestConfig) => { //进行特殊请求操作 return config; }); instance.interceptors.response.use((response: AxiosResponse) => { return response.data; });
封装请求方法
export function get<T>( url: string, params?: CustomObject, config?: CustomObject ): Promise<ResultData> { return instance.get(url, { params, ...config }); } export function post<T>( url: string, params?: CustomObject, config?: CustomObject ): Promise<ResultData> { return instance.post(url, params, config); } export function put<T>( url: string, params?: CustomObject, config?: CustomObject ): Promise<ResultData> { return instance.put(url, params, config); }
导出
export default instance;
完整代码
// http/index.ts import axios, { AxiosResponse, AxiosInstance, InternalAxiosRequestConfig, } from "axios"; const instance: AxiosInstance = axios.create({ baseURL: import.meta.env.MODE === "development" ? "/api" : import.meta.env.VITE_APP_BASE_URL, timeout: 10000, }); instance.interceptors.request.use((config: InternalAxiosRequestConfig) => { //进行特殊请求操作 return config; }); instance.interceptors.response.use((response: AxiosResponse) => { return response.data; }); export function get<T>( url: string, params?: CustomObject, config?: CustomObject ): Promise<ResultData> { return instance.get(url, { params, ...config }); } export function post<T>( url: string, params?: CustomObject, config?: CustomObject ): Promise<ResultData> { return instance.post(url, params, config); } export function put<T>( url: string, params?: CustomObject, config?: CustomObject ): Promise<ResultData> { return instance.put(url, params, config); } export default instance;
使用
// api.ts import { get, post } from "../http/index"; // 文章列表 export const blogList = (data: CustomObject): Promise<ResultData> => get("/api/posts", data);
到此这篇关于react+ ts vite搭建及二次封装请求的文章就介绍到这了,更多相关react二次封装请求内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
谈谈VUE种methods watch和compute的区别和联系
本篇文章主要介绍了谈谈VUE种methods watch和compute的区别和联系,具有一定的参考价值,有兴趣的可以了解一下2017-08-08vue3+el-table封装示例详解(编辑、删除、查看详情按钮一起封装)
在Vue3中,利用Element Plus UI库封装表格组件,实现编辑、删除和查看详情的功能,通过定义tableData和tableDataHeader来管理表格数据和表头,其中tableData通常从后端获取,而tableHeader可根据具体需求自定义,感兴趣的朋友跟随小编一起看看吧2024-09-09
最新评论