ToB企服应用市场:ToB评测及商务社交产业平台
标题:
react 封装哀求axios,直接调用即可
[打印本页]
作者:
南七星之家
时间:
2024-6-11 12:40
标题:
react 封装哀求axios,直接调用即可
概要
我们在开辟项目的时间,常常会遇到接口哀求的问题的,若我们不举行接口的统一管理,代码开辟不但多而且很贫苦轻易堕落,也倒霉于项目的维护。下面我们一下学习下react项目中将怎样封装哀求,也从另一个方面中少写一些代码。哈哈
封装流程
1、在src目次下创建文件request
2、在文件request中创建api.ts和service.ts文件(默认ts格式范例)
3、在文件中写下封装代码
api.ts(重要写api哀求接口)
export const LoginByAccount="/auth/login_weixin_by_account" //账号密码登录
export const LoginVcode="/login/vcode" //获取微信session
复制代码
service.ts(axios哀求封装)
//处理请求拦截和响应拦截
//引入
import axios from "axios";
//判断一下用户是否登录
function getToken(){ //获取token
return sessionStorage.getItem('token')
}
//3创建axios实例
let httpClient = axios.create({
baseURL:"/api",
timeout:6000,
withCredentials:true
})
//4创建请求拦截和响应拦截
httpClient.interceptors.request.use(
//成功
config=>{
if(getToken()){
config.headers['token']=getToken();
}
//返回
return config
},
//错误
err=>{
return Promise.reject(err)
}
)
//响应拦截
httpClient.interceptors.response.use(
//成功
response=>{
let res = response.data
if(res.code=='401'){
window.location.href='/login'
}
return Promise.resolve(res)
},
//错误
err=>{
return Promise.reject(err)
}
)
// 封装get请求
export const GET = (url:any, config = {}) => httpClient.get(url, config);
// 封装post请求
export const POST = (url:any, data = {}, config = {}) => httpClient.post(url, data, config);
// 封装put请求
export const PUT = (url:any, data = {}, config = {}) => httpClient.put(url, data, config);
// 封装delete请求
export const DEL = (url:any, config = {}) => httpClient.delete(url, config);
复制代码
4、页面的调用
import {POST} from "@/request/service"
import {LoginByAccount} from "@/request/api"
const getCaptchaImg = async ()=>{
//做验证码的请求
GET(LoginVcode,'').then((res:any)=>{
console.log(res);
})
}
复制代码
小结
实现起来比较简单,必要的小伙伴可以直接拿去用,在自己的项目上举行兼容调试即可
必要全部项目调试的源码可从前去
GitHub - yididid/react-manage: 重要运用了React + TypeScript + Vite + toolkit + redux技术来开辟商品管理后台,开辟了路由、接口哀求(包罗跨域办理)等基本功能的开辟,喜好的小伙伴可以拿去
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4