react18封装公共请求函数

news/2024/9/22 14:55:36/

如果里面要处理比如token过期,跳转登录这种情况的话,官方又说组件外不允许使用Hooks函数,这里可以这样做

  • 使用redux 并新建一个store/index.ts
import { configureStore, combineReducers } from '@reduxjs/toolkit'
import counterRouter from './modules/router'
import counterSlice from './modules/counterSlice'
import getDataConfig from './modules/getDataConfig'
import { persistStore, persistReducer } from 'redux-persist'
// 选择持久化存储引擎,如 localStorage 或 AsyncStorage
import storage from 'redux-persist/lib/storage' // 默认使用localStorage作为存储引擎// 组合各个模块的reducer
const reducer = combineReducers({counter: counterRouter,contText:counterSlice,getDataConfig:getDataConfig
})// 配置持久化设置
const persistConfig = {key: 'root', // 存储的键名storage, // 持久化存储引擎// 可选的配置项,如白名单、黑名单等 选其一就好了blacklist:['contText'], // 只有 test 不会被缓存// whitelist: ["test"], // 只有 test 会被缓存
}const persistedReducer = persistReducer(persistConfig, reducer)export const storeData = configureStore({reducer: persistedReducer, // 注册子模块middleware: (getDefaultMiddleware) =>getDefaultMiddleware({serializableCheck: false // 关闭默认的序列化检查//关闭严格模式})
})//获取store中的所有reducer的数据类型并导出
export type RootState = ReturnType<typeof storeData.getState>
//提取dispatch数据类型
export type AppDispatch = typeof storeData.dispatch;export const persistor = persistStore(storeData)
这样的话,其他地方你就可以直接引入store文件,然后使用里面的方法或者获取store数据,不用在使用hooks函数

如果要跳转路由的话,可以这样window.location.href = “/login”;

新建request.ts //1.引入vue
// import Vue from 'vue'
//2.引入axios库
import axiosNew from 'axios';
import config from '@/config/index'//引入公用文件
import { useNavigate } from 'react-router-dom';
import { useDispatch, useSelector } from 'react-redux';
import { AppDispatch, RootState } from '@/store';
import { setToken } from '@/store/modules/getDataConfig';
// 引入 pinia  token
import {storeData} from "@/store"
import { increment } from '@/store/modules/router';// 引入接口地址axiosNew.defaults.timeout =3000;//请求超时时间axiosNew.interceptors.request.use(//请求拦截(config:any) => {// const useUserData=loginStore.tokenStore();config.headers['content-type'] = 'application/x-www-form-urlencoded';// console.log(config.headers,"请求头----",useSelector)// if (userToken) {//如果有token给请求头加上//     config.headers['authorization'] =userToken// }return config},err => {return Promise.reject(err);})
// let router=useRouter();// 获取登录TOKEN信息axiosNew.interceptors.response.use(response => {//相应拦截try{}catch(err){// console.log("在相应拦截这边其他请求不需要取token",err)};if(response.data.code==10001||response.data.code==402){//如果token为空或者过期,跳到登录// const dispatch: AppDispatch = useDispatch()// 清空token// dispatch(setToken(""))// 跳转登录}return response;
},err=>{return Promise.reject(err)}
);
function getTOken(){}
// axiosNew.defaults.baseURL=""
const axios=function(path:string,method:string,data:any){// const routerStroe=useSelector((state:RootState) => state.getDataConfig)var header:any;// 如果存在token就放进去header=config.headersreturn new Promise((resolve,reject)=>{let datas:any={params:{...data}}// let b=qs.parse(datas)if(method==="POST"||method=="post") datas={...{data}};// console.log(qs.stringify(data),"参数---",b)axiosNew({url:`${config.url}/xys/api/${path}`,method,header: header,...datas}).then(res=>{if(res.data.code == 0){resolve(res.data.data)}else if([410000, 410001, 410002, 10032].indexOf(res.data.code) !== -1){// 登录过期跳转登录页window.location.href = "/login";//    清空storeData.dispatch(setToken(""))}else{resolve(-1)// ElMessage.error(res.data.message)}}).catch(err=>{storeData.dispatch(setToken(""))// const navigate=useNavigate()// navigate("/login")// window.location.href = "/login";resolve(-1)// ElMessage.error('请求失败,请稍后再试...')})})
};
const request:any = {};['options', 'get', 'post', 'put', 'head', 'delete', 'trace', 'connect'].forEach((method) => {request[method] = (api: any, data: any, opt: any) => axios(api, method, data)
});
export default request

http://www.ppmy.cn/news/1460028.html

相关文章

2024OD机试卷-整型数组按个位值排序(java\python\c++)

题目:整型数组按个位值排序 题目描述 给定一个非空数组(列表),其元素数据类型为整型,请按照数组元素十进制最低位从小到大进行排序,十进制最低位相同的元素,相对位置保持 当数组元素为负值时,十进制最低位等同于去除符号位后对应十进制值最低位。 输入描述 给定一个…

Minio 纠删码及分布式Minio集群环境搭建

系列文章目录 第二章 Minio 纠删码及分布式Minio集群环境搭建 Minio 纠删码及分布式Minio集群环境搭建 系列文章目录纠删码什么是纠删码&#xff1f;为什么纠删码有用?什么是位衰减bit rot保护? 纠错码单机模式环境搭建分布式MinIO分布式存储可靠性常用方法冗余校验 分布式M…

Python小程序 - 文件处理1(使用AI工具)

使用 AI进行Python 小程序开发&#xff0c;会是什么样子的&#xff1a;只要你问的准&#xff0c;AI给出的答案&#xff1f;自己试试看&#xff0c;入门越来越低。 人还要做什么&#xff1f;还能做什么&#xff1f; 需求&#xff1a;给定目录 -- 需求持续补充中 1&#…

P1101 单词方阵

题目描述: 给一 &#x1d45b;&#x1d45b;nn 的字母方阵&#xff0c;内可能蕴含多个 yizhong 单词。单词在方阵中是沿着同一方向连续摆放的。摆放可沿着 88 个方向的任一方向&#xff0c;同一单词摆放时不再改变方向&#xff0c;单词与单词之间可以交叉&#xff0c;因此有可…

https://是怎么实现的?

默认的网站建设好后都是http访问模式&#xff0c;这种模式对于纯内容类型的网站来说&#xff0c;没有什么问题&#xff0c;但如果受到中间网络劫持会让网站轻易的跳转钓鱼网站&#xff0c;为避免这种情况下发生&#xff0c;所以传统的网站改为https协议&#xff0c;这种协议自己…

C++语法之在谈const与模版参数

最近一直在复习C的语法&#xff0c;感觉遇到了不少问题&#xff0c;或许是之前没想的这么深。废话不说&#xff0c;开始说正事。 一、再谈const 有些朋友可能有些疑问&#xff0c;不就是const吗&#xff1f;我知道&#xff0c;const可以给非const赋值&#xff0c;反过来不行&…

网络安全等级保护的发展历程

1994年国务院147号令第一次提出&#xff0c;计算机信息系统实行安全等级保护&#xff0c;这也预示着等保的起步。 2007年《信息安全等级保护管理办法》的发布之后。是等保在各行业深耕落地的时代。 2.0是等保版本的俗称&#xff0c;不是等级。等保共分为五级&#xff0c;二级…

C++算法之区间合并

本文介绍区间合并相关知识点 目录 文章目录 前言 区间合并 概述 做法 n个区间合并 校门外的树 总结 前言 本文介绍区间合并这一基础算法&#xff0c;介绍常规的做法以及模板 区间合并 概述 通常区间合并是给定数个区间&#xff0c;想要将有交集的区间合并成一个区间 如下要…