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集成的核心点:状态同步、生命周期管理和错误边界。多练手几次,就能在真实项目里游刃有余了。如果有问题,欢迎在评论区交流,大家一起进步!

相关推荐
WenGyyyL12 小时前
ColBERT论文研读——NLP(IR)里程碑之作
人工智能·python·语言模型·自然语言处理
哈哈很哈哈15 小时前
深度学习中的分布式并行策略和内存优化技术
人工智能·语言模型
奔跑的呱呱牛15 小时前
arcgis-to-geojson双向转换工具库
arcgis·json
qq_2816842116 小时前
Transformer-XL:突破固定长度枷锁,重构长文本语言模型
人工智能·深度学习·语言模型·重构·transformer
智算菩萨18 小时前
基于多模态基础模型迈向通用人工智能:BriVL模型深度解析
论文阅读·人工智能·ai·语言模型·agi
人工智能培训咨询叶梓19 小时前
SYNCHECK:提升检索增强型语言模型的可信度
人工智能·深度学习·语言模型·大模型·检索增强·多模态·rag
Predestination王瀞潞19 小时前
4.1.1 存储->数据库:MongoDB
数据库·mongodb
南宫乘风20 小时前
Qwen2.5-7B 指令(LoRA)微调完整实战指南
ai·语言模型·训练
老鱼说AI20 小时前
CUDA架构与高性能程序设计:多维网格与数据
c++·人工智能·深度学习·神经网络·机器学习·语言模型·cuda
AI成长日志21 小时前
【datawhale】hello agents开源课程第3章学习记录:大语言模型基础学习心得博客
学习·语言模型·开源