说到发送请求,首先得解决跨域这个老大难。在项目根目录创建个proxy配置文件最省事:
配完这个,前端直接用就能访问后端的,不用再被CORS政策卡脖子。
接下来看看怎么在组件里优雅地调接口。刚开始我都是这么写的:
这么写虽然能用,但每个需要调接口的组件都得重复写这套逻辑,太麻烦了。后来我学聪明了,直接把API调用封装成自定义Hook:
封装成Hook之后,组件里用起来就清爽多了:
POST请求也得好好处理。很多人只记得设置method,忘了设置headers,结果后端收不到数据:
在实际项目里,我建议用axios替代fetch。axios自动处理JSON转换,错误处理也更直观:
处理加载状态也有讲究。我之前就犯过傻,在同一个页面里放了三个独立加载状态,用户体验很割裂。后来改用全局状态管理加载:
错误处理也不能马虎。除了网络错误,还得考虑HTTP状态码错误:
对于需要频繁调用的API,比如搜索建议,还得加上防抖:
总的来说,React项目里调API看似简单,实际要考虑的细节真不少。从基础请求发送到错误处理、性能优化,每个环节都得处理好。关键是要保持代码整洁和可维护性,别让API调用逻辑散落在各个角落。把这些最佳实践用熟了,开发效率能提升不少,代码质量也更有保障。