React项目中怎么封装请求接口
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,本文小编为大家详细介绍"React项目中怎么封装请求接口",内容详细,步骤清晰,细节处理妥当,希望这篇"React项目中怎么封装请求接口"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习
千家信息网最后更新 2025年01月22日React项目中怎么封装请求接口
本文小编为大家详细介绍"React项目中怎么封装请求接口",内容详细,步骤清晰,细节处理妥当,希望这篇"React项目中怎么封装请求接口"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
1.包含文件:
在我们的封装的过程中需要使用到这三个文件;Api.js、Apilp.js和ApiURL.js。
2.ApiIp.js文件的作用:
该文件的作用是调用不同的接口请求地址在开发环境和生产环境下,在生产环境下这个文件的作用是动态的获取浏览器中的地址进行拼装,从而可以动态的获取地址。代码和注释如下:
//获取当前的URL中的地址,同时携带端口号,不携带http://let projectAddrass = _window.location.host;let projectAddrassNoPort = _window.location.hostname;//返回当前的URL协议,既http协议还是https协议let protocol = _document.location.protocol;//封装请求接口的地址,如果服务器中套了一层性项目名称,需要在这里面添加上,需要留意,例如: /zzxl/export const interfaceIp = `${protocol}//${projectAddrass}/zzxl`;//LOGO图片的请求地址export const logoImgAddress = `${protocol}//${projectAddrassNoPort}`;//对外提供的服务地址export const publicIp = process.env.NODE_ENV === 'development' ? 'http://10.222.40.243:8088' :interfaceIp;export const logoImgIp = process.env.NODE_ENV === 'development' ? 'http://127.0.0.1' :logoImgAddress;
3.Api.js文件的作用:
这个文件通过对外请求接口服务的入口文件,然后再通过借助于axios 再次封装,从而来返回为Promise 对象,因为在Promise这个对象中含有 then 和 catch 这两个方法可以让我们便于进一步的处理。代码注释如下:
import axios from 'axios';import * as apiUrl from './ApiURL';import {notification} from 'antd';const key = 'keepOnlyOne';/** * 接口请求数据时执行的方法 * 接受参数为请求的路径apiUrl、请求接口配置参数configObj * * @param {String} apiUrl 用户传入的请求路径 * @param {Object} configObj 用户传入的接口参数 */function getDataFromServer(apiUrl, configObj) { //用户传入的接口配置参数 let { method = 'GET', params = {}, data = {}, timeout = 5000 } = configObj; /** * 返回的Promise对象含有then、catch方法 */ return new Promise(function (resolve, reject) { axios({ url: apiUrl, method: method, params: params, data: data, timeout: timeout, headers: { 'Content-Type': 'application/json', 'token': window.sessionStorage.getItem('token') || '' } }).then(function (response) { if(response){ if (response.data && response.data.code) { resolve(response); }else { notification.error({ key, message: '操作失败', description: '返回的数据格式有误' }); resolve(response); } }else { //处理特殊的情况就是response返回什么也没有 notification.error({ key, message: '操作失败', description: '服务器错误' }); resolve(response); } }).catch(function (error) { notification.error({ key, message: '操作失败', description: '网络异常,请稍后重试' }); reject(error); }) })}// 登录export function loginClick(configObj) { return getDataFromServer(apiUrl.LOGIN, configObj);}
其他的Dome文件添加这些代码:
import { loginClick } from '../Api';// 使用let loginInfo = {method: 'POST',data: {account: username}}loginClick(loginInfo).then((response) => {// do something}).catch((error)=>{ // error something})
4.ApiURL.js文件的作用:
通过ApiIp.js这个文件传入的地址,然后封装具体的一个请求路径从而拼装成完整的请求地址,将得到的所有接口请求的地址存放到一个文件中,这样可以降低耦合度还便于我们的维护。代码如下:
import ApiIP from './ApiIp';// 登录export const LOGIN = `${ApiIP}/index/captcha`;
读到这里,这篇"React项目中怎么封装请求接口"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。
文件
接口
地址
封装
作用
项目
代码
参数
服务
对象
文章
方法
环境
用户
路径
处理
内容
动态
数据
服务器
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
国内做网络安全排名
mysql本地数据库ip
找不到管理您的服务器
吉林省机关特别重大网络安全事件
章节数据存储数据库
数据库中怎么查工作岗位
方舟怎么删除服务器
绍兴制造软件开发费用
长春软件开发搜吉网传媒
服务器硬盘数据怎么保证
7项技术护航网络安全
寻甸方便软件开发市场报价
数据跨境传输的网络安全
京东商城的数据库设计
国家网络安全法弊端
软件开发 瀑布模型的核心
祁门县软件开发商是谁
网络安全杂志 app
虚拟机配置服务器配置
北工大安全软件开发
世界最大材料数据库
system x 服务器
服务器怎么中病毒
智能互联网络技术专业准备什么
我的世界手机版服务器生存1
智能软件开发销售价格
长春软件开发搜吉网传媒
虹口区媒体数据库服务价格查询
软件开发工程师证书英语翻译
服务器散热上市公司