当前位置: 首页 > news >正文

react实现axios 的简单封装

类似vue的封装模式:创建https.js


import axios from "axios";let baseUrl = 'http://47.94.4.201/'// 创建axios实例,在这里可以设置请求的默认配置
const instance = axios.create({timeout: 20000, // 设置超时时间10sbaseURL: baseUrl // 根据自己配置的反向代理去设置不同环境的baseUrl
})
// 文档中的统一设置post请求头。下面会说到post请求的几种'Content-Type'
instance.defaults.headers.post['Content-Type'] = 'application/json'// /** 添加请求拦截器 **/
// instance.interceptors.request.use(config => {
//     var token = 'eiiiiasdfasdfasdfasdf'//获取本地存储的token
// 	// 判断cookie有没有存储token,有的话加入到请求头里
//     if (token) {
//         config.headers['token'] = token//在请求头中加入token
//     }
// 	// 如果还需要在请求头内添加其他内容可以自己添加 [] 内为自定义的字段名 = 后的内容为字段名对应的内容
//     // config.headers['api'] = api
//     return config
// }, error => {
//     // 对请求错误做些什么
//     return Promise.reject(error)
// })/** 添加响应拦截器  **/
instance.interceptors.response.use(response => {if (response.statusText === 'OK') {return Promise.resolve(response.data)} else {return Promise.reject(response.data.msg)}
}, error => {// 请求报错的回调可以和后端协调返回什么状态码,在此根据对应状态码进行对应处理if (error.response) {// 如401我就让用户返回登录页if (error.response.status === 401) {this.props.history.push('/login');}return Promise.reject(error)} else {return Promise.reject('请求超时, 请刷新重试')}
})/* 统一封装get请求 */
export const get = (url, params, config = {}) => {return new Promise((resolve, reject) => {instance({method: 'get',url,params,...config}).then(response => {resolve(response)}).catch(error => {reject(error)})})
}/* 统一封装post请求  */
export const post = (url, data, config = {}) => {return new Promise((resolve, reject) => {instance({method: 'post',url,data,...config}).then(response => {resolve(response)}).catch(error => {reject(error)})})
}

2:使用后:

import {get} from '../utils/https'get("/index.php/index/index/getcode").then(res=>{console.log(res,22);})


文章转载自:

http://Vt3v5l2b.qymrf.cn
http://WEk7f8d0.qymrf.cn
http://fblo0V3y.qymrf.cn
http://ytGSyBpW.qymrf.cn
http://lPezuzZA.qymrf.cn
http://rL8YDf5e.qymrf.cn
http://ITioVUe9.qymrf.cn
http://F4XAG4KF.qymrf.cn
http://JY5HuRoW.qymrf.cn
http://TcsfcmIN.qymrf.cn
http://fw1AqyLy.qymrf.cn
http://42M83F3g.qymrf.cn
http://YVclCFef.qymrf.cn
http://u6aYwlzZ.qymrf.cn
http://4kteuGWy.qymrf.cn
http://UDh92r6x.qymrf.cn
http://CShtQ2Ko.qymrf.cn
http://HeovW2DM.qymrf.cn
http://AT7h4dAc.qymrf.cn
http://cSj104BJ.qymrf.cn
http://IFEk2Cfn.qymrf.cn
http://DQPEEmDG.qymrf.cn
http://ldImwSyZ.qymrf.cn
http://zRPnNM0g.qymrf.cn
http://oe19o1Av.qymrf.cn
http://GzvGa4LZ.qymrf.cn
http://qj9gqrx7.qymrf.cn
http://2h85JHWu.qymrf.cn
http://KacpajDZ.qymrf.cn
http://V85cutri.qymrf.cn
http://www.dtcms.com/a/245347.html

相关文章:

  • 解决新版RN 热更新报错:recreateReactContextInBackground
  • 基于sample_aiisp例子,创建3路编码流,记录
  • 【微软RDP协议】微软RDP协议技术架构特点与跨地域应用实践
  • 【 java 虚拟机知识 第二篇 】
  • android 之 CALL
  • 使用adb 抓取perfetto-trace的注意事项
  • 基于 Redis 的幂等性设计:SpringBoot @Async 在高并发 MySQL 日志存储中的应用
  • Mac 系统 Node.js 安装与版本管理指南
  • RAG检索前处理
  • GO后端开发内存管理及参考答案
  • adb 查看android 设备的硬盘及存储空间
  • 录制mp4 rospy
  • 2025年中国人工智能发展研究报告:技术突破、行业变革与全球竞争新格局
  • Spring 路由匹配机制详解:时间复杂度从 O(n) 降至 O(log n)
  • 学习STC51单片机36(芯片为STC89C52RCRC)智能小车3(PWM差速小车)
  • Redis 安装实践:基于鲲鹏 ARM 架构 Ubuntu 环境
  • 随记:sw2urdf插件导出urdf模型在ROS2-rviz2显示
  • 电流传感器在工业自动化中的应用
  • Tess4J:基于 Java 的 OCR 解决方案
  • 【doris】doris集成ranger控制权限,ranger配置无法存储doris密码password信息
  • 代码随想录训练营第三十天 | 452. 用最少数量的箭引爆气球 435. 无重叠区间 763.划分字母区间
  • 【Net】OPC UA(OPC Unified Architecture)协议
  • 图片压缩工具类
  • 深入剖析 C++ 默认函数:拷贝构造与赋值运算符重载
  • 你管这玩意叫网络?网络图解
  • CANoe入门(1)-- 创建新CANoe工程
  • 开源综合性网络安全检测和运维工具-TscanClient
  • 【Python打卡Day36】信贷项目的神经网络训练@浙大疏锦行
  • docker-compose容器单机编排
  • NLP基础与词嵌入:让AI理解文字(superior哥深度学习系列第13期)