欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react+?ts?vite搭建及二次封裝請求的過程解析

 更新時間:2023年04月23日 09:56:05   作者:——a  
這篇文章主要介紹了react+?ts?vite搭建及二次封裝請求,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

1.搭建項目

npm create vite

在這里插入圖片描述

2.下載axios

npm install axios 

打開項目創(chuàng)建基本項目結構

在這里插入圖片描述

3.創(chuàng)建http文件夾下index.ts

引入axios

import axios, {
  AxiosResponse,
  AxiosInstance,
  InternalAxiosRequestConfig,
} from "axios";

重新創(chuàng)建axios

const instance: AxiosInstance = axios.create({
  baseURL:
  	// vite 環(huán)境變量判斷
    import.meta.env.MODE === "development"
      ? "/api"
      : import.meta.env.VITE_APP_BASE_URL,
  timeout: 10000,
});

創(chuàng)建攔截器

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二次封裝請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue2 Vue-cli中使用Typescript的配置詳解

    Vue2 Vue-cli中使用Typescript的配置詳解

    Vue作為前端三大框架之一截至到目前在github上以收獲44,873顆星,足以說明其以悄然成為主流。下面這篇文章主要給大家介紹了關于Vue2 Vue-cli中使用Typescript的配置的相關資料,需要的朋友可以參考下。
    2017-07-07
  • vue3 非父子組件通信詳解

    vue3 非父子組件通信詳解

    本篇文章主要介紹了詳解Vue 非父子組件通信,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • Vue兼容ie9的問題全面解決方案

    Vue兼容ie9的問題全面解決方案

    這篇文章主要介紹了Vue兼容ie9的問題全面解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Vue實現(xiàn)訂單支付倒計時功能

    Vue實現(xiàn)訂單支付倒計時功能

    這篇文章主要給大家介紹了Vue實現(xiàn)訂單支付倒計時功能,倒計時這要運用在創(chuàng)建訂單后15分鐘內(nèi)進行支付,否則訂單取消,本文結合示例代碼給大家詳細講解,需要的朋友可以參考下
    2023-08-08
  • vue?this.$refs.xxx報錯undefined問題及解決

    vue?this.$refs.xxx報錯undefined問題及解決

    這篇文章主要介紹了vue?this.$refs.xxx報錯undefined問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue項目中axios如何捕捉http狀態(tài)碼為401錯誤問題

    vue項目中axios如何捕捉http狀態(tài)碼為401錯誤問題

    這篇文章主要介紹了vue項目中axios如何捕捉http狀態(tài)碼為401錯誤問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue3使用dataV報錯問題的解決方法

    Vue3使用dataV報錯問題的解決方法

    這篇文章主要為大家詳細介紹了Vue3中使用dataV報錯問題的解決方法,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-11-11
  • vue watch immediate方法用法詳解

    vue watch immediate方法用法詳解

    這篇文章主要介紹了vue watch immediate方法用法詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • vue3?vite異步組件及路由懶加載實戰(zhàn)示例

    vue3?vite異步組件及路由懶加載實戰(zhàn)示例

    這篇文章主要為大家介紹了vue3?vite異步組件及路由懶加載實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • vue3如何將html元素變成canvas(海報生成),進行圖片保存/截圖

    vue3如何將html元素變成canvas(海報生成),進行圖片保存/截圖

    這篇文章主要介紹了vue3實現(xiàn)將html元素變成canvas(海報生成),進行圖片保存/截圖,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評論