React 入门第九天:与后端API的集成与数据管理

在React学习的第九天,我集中学习了如何与后端API进行集成。这一步是将静态的React应用转变为动态、可交互的关键。通过与后端通信,我们可以从服务器获取数据、发送用户输入以及处理复杂的业务逻辑。

1. 使用fetch进行数据请求

React没有内置的HTTP库,因此我们通常使用浏览器提供的fetch API或第三方库如axios来发送请求。

以下是一个使用fetch从API获取数据的示例:

import React, { useState, useEffect } from 'react';function DataFetchingComponent() {const [data, setData] = useState([]);const [loading, setLoading] = useState(true);useEffect(() => {fetch('https://api.example.com/data').then(response => response.json()).then(data => {setData(data);setLoading(false);}).catch(error => {console.error('Error fetching data:', error);setLoading(false);});}, []);if (loading) {return <div>加载中...</div>;}return (<div>{data.map(item => (<div key={item.id}>{item.name}</div>))}</div>);
}export default DataFetchingComponent;

在这个例子中,我们使用useEffect在组件加载时发送HTTP请求,获取的数据存储在data状态中,并根据loading状态显示加载指示。

2. 使用axios进行数据请求

虽然fetch API足够强大,但在实际项目中,开发者更倾向于使用axios,因为它提供了更丰富的功能,如自动处理JSON、支持拦截器等。

import React, { useState, useEffect } from 'react';
import axios from 'axios';function DataFetchingComponent() {const [data, setData] = useState([]);const [loading, setLoading] = useState(true);useEffect(() => {axios.get('https://api.example.com/data').then(response => {setData(response.data);setLoading(false);}).catch(error => {console.error('Error fetching data:', error);setLoading(false);});}, []);if (loading) {return <div>加载中...</div>;}return (<div>{data.map(item => (<div key={item.id}>{item.name}</div>))}</div>);
}export default DataFetchingComponent;

axios的使用方法与fetch类似,但它的API更加简洁,并且自动处理了JSON解析。

3. 数据的POST请求与表单处理

除了获取数据外,React应用通常还需要发送数据到服务器,例如处理表单提交。以下是一个简单的POST请求示例:

function SubmitFormComponent() {const [inputValue, setInputValue] = useState('');const handleSubmit = (event) => {event.preventDefault();axios.post('https://api.example.com/submit', { input: inputValue }).then(response => {console.log('Data submitted:', response.data);}).catch(error => {console.error('Error submitting data:', error);});};return (<form onSubmit={handleSubmit}><inputtype="text"value={inputValue}onChange={(e) => setInputValue(e.target.value)}/><button type="submit">提交</button></form>);
}

这里我们处理了表单的提交,通过axios.post发送用户输入的数据到服务器。

4. 处理请求状态与错误

在实际应用中,处理请求的各种状态(如加载、成功、失败)是非常重要的。以下是如何在React中优雅地处理这些状态的一个示例:

function EnhancedDataFetchingComponent() {const [data, setData] = useState([]);const [loading, setLoading] = useState(true);const [error, setError] = useState(null);useEffect(() => {axios.get('https://api.example.com/data').then(response => {setData(response.data);setLoading(false);}).catch(error => {setError('Failed to fetch data');setLoading(false);});}, []);if (loading) {return <div>加载中...</div>;}if (error) {return <div>{error}</div>;}return (<div>{data.map(item => (<div key={item.id}>{item.name}</div>))}</div>);
}

在这个例子中,我们通过状态管理对加载状态、成功状态和错误状态进行了区分,确保在不同的状态下展示不同的内容。

5. 小结与展望

第九天的学习让我掌握了React与后端API交互的基本方法,从GET请求获取数据到POST请求提交数据,再到如何处理各种状态和错误,这些都是构建动态应用时不可或缺的技能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/878596.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Assembly 跨域通信AppDomain

Assembly 怎么实现跨域通信 在 .NET Framework 中&#xff0c;AppDomain 是一种用于隔离应用程序的机制&#xff0c;可以在单个进程内创建多个应用程序域&#xff08;AppDomain&#xff09;。每个应用程序域都有自己的程序集、资源和内存空间。通过使用 AppDomain&#xff0c;…

Linux 搭建 Java 部署环境:安装 JDK 和 MySQL 的教程

目录 一、apt 二、JDK 2.1 更新软件包 2.2 安装openjdk 三、MySQL 3.1 使用apt安装MySQL 3.2 查看MySQL的状态 3.3 MySQL 安装安全设置 3.4 设置密码 一、apt apt(Advanced Packaging Tool), Linux软件包管理工具&#xff0c;用于在Ubuntu、Debian和相关Linux发行版上…

OcrLiteNcnn:Windows环境打包及Java调用

目录结构 前言cmake安装源码下载说明Windows源码编译执行“cmake -DCMAKE_BUILD_TYPE=Release ..”执行“cmake --build . --config Release -- -m:6”编译完成识别图片命令行调用Java调用前言 Java实现OCR识别图片中的文字,小编先前整理过一篇在Linux环境中基于“ChineseOcr…

OpenCV入门12.2:SURF与SIFT比较及SURF示例

SIFT (Scale-Invariant Feature Transform): 提出时间: 1999年&#xff0c;由David Lowe提出。关键特点: 能够检测和描述图像中的关键点&#xff0c;这些关键点对旋转、缩放和部分亮度变化具有不变性。计算复杂度: 相对较高&#xff0c;因为SIFT使用了高斯差分核来检测关键点&…

小程序面试题二

一、微信小程序的开发原理是什么&#xff1f; 微信小程序的开发原理主要基于Web规范&#xff0c;采用HTML、CSS和JavaScript等前端技术&#xff0c;并结合微信官方提供的特定框架和API进行开发。以下是小程序开发原理的详细解析&#xff1a; 1. 开发框架与语言 WXML&#xff…

全局安装react

1、首先安装react脚手架 npm install -g create-react-app2、创建react项目 create-react-app my-app3、 PS D:\桌面\papers\subject> create-react-app my-react-appCreating a new React app in D:\桌面\papers\subject\my-react-app.Installing packages. This might …

解释 JVM 的内存模型(堆、栈、方法区等),并简述如何通过调整 JVM 参数来优化应用程序的性能?

JVM&#xff08;Java Virtual Machine&#xff09;的内存模型是 Java 程序运行的基础&#xff0c;理解它的各个组成部分对于优化应用程序的性能至关重要。 JVM 的内存模型主要包括以下几个部分&#xff1a; 堆&#xff08;Heap&#xff09;栈&#xff08;Stack&#xff09;方…

数据结构(1)数据结构基础(单向链表)

一、什么是数据结构 数据结构是一组用来保存一种或多种特定关系的数据的集合。其主要目的是组织和存储数据&#xff0c;以便于高效的访问和修改。在程序设计中&#xff0c;将大量而复杂的问题以特定的数据类型和特定的存储结构存储在内存中&#xff0c;并在此基础上实现某个特定…

Docker安装Neo4j图数据库和APOC插件

文章目录 一、前言二、安装Neo4j三、测试Neo4j四、安装APOC插件五、测试APOC插件 一、前言 官方文档&#xff1a;https://neo4j.com/docs/operations-manual/current/docker/introduction/ 二、安装Neo4j 我这里以 5.23.0 版的 Neo4j 为例 拉取镜像 docker pull neo4j:5.23.0…

Java-用户线程与守护线程

在Java中&#xff0c;线程分为用户线程和守护线程。用户线程是程序的主要线程&#xff0c;而守护线程则是为用户线程提供支持的后台线程。以下是对这两种线程的详细解释以及示例代码。 用户线程与守护线程的区别 用户线程&#xff1a; 用户线程是应用程序中执行的主要线程&…

HarmonyOS NEXT 应用运行异常记录与解决(持续整理版)

问题一 App Launch Failed to get the device apiVersion. 解决方案 进入到设备管理&#xff0c;点击对应开启的模拟器设备&#xff0c;先将模拟器关闭&#xff0c;然后点击查出掉用户数据&#xff0c;再重启。 重启之后&#xff0c;一般能解决。如果遇到还是显示拿不到apiVer…

《第三十四章 高级主题 - 动画效果》

在 Android 应用开发中&#xff0c;动画效果能够显著提升用户体验&#xff0c;使应用更加生动和吸引人。本章将深入探讨 Android 中的动画效果&#xff0c;包括属性动画、帧动画以及 ViewPager 动画。 一、属性动画 &#xff08;一&#xff09;属性动画简介 属性动画是 Android…

bash反弹shell分析

目录 介绍步骤 介绍 与目标主机建立连接的原理是利用漏洞执行ShellCode。 GetShell的实质是&#xff1a;执行ShellCode&#xff0c;将目标主机的Shell重定向到攻击机。拿到Shell利于后续的渗透。 所谓的反弹Shell是指GetShell的过程由目标主机主动发起&#xff08;反向连接&a…

Git如何安装和配置

一、Git 的安装 1、Git 的官网 Git (git-scm.com) 2、下载 Git for Windows 在官网下载好 Git 的安装文件后&#xff0c;接下来就可以进行安装了。 3、安装 Git 以管理员身份运行你下载的安装文件&#xff1a; 然后就可以进入安装向导了。 4、验证是否安装成功 当安装向…

测试分类简介

1.按照测试⽬标分类 1&#xff09;界面测试&#xff1a; 界⾯测试&#xff08;简称UI测试)&#xff0c;指按照界⾯的需求&#xff08;⼀般是UI设计稿&#xff09;和界⾯的设计规则&#xff0c;对我们软件界⾯所展⽰的全部内容进⾏测试和检查。 2&#xff09;功能测试&#xff…

内存管理(三)--Linux CMA内存使用

文章目录 一、预留一段内存常用方法1.1 设备树定义reserve memory 二、内存节点常见属性2.1 no-map和reusable使用上的区别 三、预留CMA的reserved memory方法3.1 共享cma&#xff08;采用设备树&#xff09;3.2 共享cma&#xff08;采用bootargs&#xff09;3.3 私有cma 四、使…

【数据结构】--初始集合框架

1. 什么是集合框架 集合框架:Java中已经实现好的集合类&#xff08;一些已经由Java实现好的数据结构&#xff09;。Java的数据结构和C语言的数据结构是没有什么区别的&#xff0c;里面的区别就只是实现的语言不一样。不可能出现Java的单链表和C语言实现的单链表是两个不同的东…

idea配置svn发现安装的svn中的bin目录下没有svn.exe文件

问题描述 使用idea配置svn时&#xff0c;发现安装的svn没有svn.exe文件 解决方法 1、双击svn安装包&#xff0c;找到【modify】 2、默认安装时&#xff0c;没有安装command line client tools&#xff0c;里面是有svn.exe 3、选择will be installed on local hard drive 4、…

idea中使用git提交代码报错husky > pre-commit

1、原因&#xff1a; 本地项目中的.git下的一个文件导致的提交失败&#xff0c;这个文件是pre-commit文件。由于预提交钩子pre-commit导致的提交失败&#xff0c;通过删除.git/hooks/pre-commit文件可以解决 2、解决步骤&#xff1a; 1、找到项目中的.git文件夹&#xff0c;…

鸿蒙-右边固定长度,左边超长Text自适应

Component Entry struct test {build() {Row() {Column() {Text(长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串长字符串).maxLines(1).textOverflow({ overflow: TextOverflow.Ellipsis…