ReactRESTfulAPI案例

先简单唠唠什么是RESTful API。说白了,它就是一套设计Web服务的规范,用HTTP方法像GET、POST、PUT、DELETE来对应数据的增删改查。在React里,我们经常用fetch或者axios这些工具来发请求,把后端返回的JSON数据渲染到组件里。这个案例呢,我选了一个常见的场景------用户列表管理,模拟从服务器获取用户数据,并支持添加和删除操作。后端我用了一个免费的测试API,JSONPlaceholder,它提供了模拟的REST端点,很适合练手。

首先,得搭建一个React项目。如果你用Create React App,直接npx create-react-app my-app就能搞定。然后,在组件里,我们需要用useState来管理状态,比如存储用户列表、加载状态和错误信息。再用useEffect来处理副作用,比如组件挂载时自动拉取数据。代码大致长这样:

这段代码实现了基础的数据获取和显示。useEffect里的依赖数组是空的,所以只会在组件第一次渲染时执行。用async/await处理异步请求,比回调函数看起来清爽多了。加载中和错误状态也做了简单处理,避免用户看到白屏。

接下来,扩展一下功能,加上添加用户的操作。这里需要用到POST请求,并且更新本地状态。我添加了一个表单,用户输入名字和邮箱后,提交到API。注意,JSONPlaceholder的POST端点虽然会返回模拟的响应,但不会真正修改服务器数据,所以本地状态得手动更新。代码可以这么写:

然后在主组件里集成这个AddUser,通过props传递一个回调函数来更新users状态。这里注意,由于JSONPlaceholder的POST返回的数据带id,我们可以直接用它来更新列表。如果是真实项目,可能需要根据后端实际响应调整。

删除功能也类似,用DELETE请求,并在成功后从本地状态移除对应项。代码片段:

在实际项目中,这些API调用可能会抽象成自定义Hook,比如useUsers,这样逻辑更复用,也便于测试。另外,错误处理可以更细化,比如用状态码判断是网络问题还是服务器错误,给用户更友好的提示。还有,加载状态可以用骨架屏代替简单的文字,提升用户体验。

最后,别忘了测试。用浏览器开发者工具检查网络请求,或者写点单元测试验证组件行为。这个案例虽然简单,但覆盖了React和RESTful API集成的核心点:状态同步、生命周期管理和错误边界。多练手几次,就能在真实项目里游刃有余了。如果有问题,欢迎在评论区交流,大家一起进步!

相关推荐
风落无尘3 小时前
第九章《语言与理解》 完整学习资料
gpt·rnn·语言模型·transformer
malog_3 小时前
大语言模型后训练全解析
人工智能·深度学习·机器学习·ai·语言模型
神秘的土鸡4 小时前
Agent 落地:贴合健身真实场景的 AI 人物跟练方案
ai·语言模型·agent
qq_525513757 小时前
# 第七章 指令微调学习(四) 7.6基于指令数据对大语言模型进行微调
深度学习·学习·语言模型
玄米乌龙茶1237 小时前
LLM成长笔记(四):大语言模型(LLM)基础认知
人工智能·笔记·语言模型
Yingjun Mo7 小时前
(二) LLM探索能力-1. 大语言模型能够进行上下文探索吗?
人工智能·语言模型·自然语言处理
tzc_fly8 小时前
LLaDA2.0-Uni:基于扩散语言模型的统一多模态理解和生成
人工智能·语言模型·自然语言处理
弹简特9 小时前
【Vue3速成】01-npm+vue初体验+vite构建vue工程化
vue.js·arcgis·npm
AI技术控9 小时前
LangChain 是什么?从零开始学会 LangChain 的工程实践指南
人工智能·语言模型·自然语言处理·langchain·nlp
liudanzhengxi9 小时前
巧用ULN2003A轻松扩展单片机IO口
数据库·mongodb