首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何为react js中的所有页面重用API数据?

如何为react js中的所有页面重用API数据?
EN

Stack Overflow用户
提问于 2020-10-17 12:35:50
回答 3查看 1.1K关注 0票数 3

我是react js的新手。我正在建立一个4-5页的网站使用反应js。在所有页面中,都有一个名为category的API。请求此API一次并在需要的所有页面上使用相同数据的最佳方式是什么?我试图在google上查找,但没有得到令人满意的结果,所以您的指南将有助于节省客户端资源,以便一次又一次地为每个组件或页面调用相同的API。

非常感谢!

EN

回答 3

Stack Overflow用户

发布于 2020-10-17 12:43:23

这个问题的答案取决于你想要的阻力范围。如果您想在每次重新加载时都重做API调用,那么您可以使用Redux之类的东西在多个组件之间共享输出。如果你想让它保存更长时间,你可以使用LocalStorage。请注意,如果您只想临时存储,也可以使用LocalStorage,但您需要添加代码,以便在应用程序加载期间从应用程序接口获取数据。

票数 2
EN

Stack Overflow用户

发布于 2020-10-17 13:22:53

为了更好地处理获取数据和缓存数据以供下次使用,您可以轻松地使用两个功能强大的库

react-query https://www.npmjs.com/package/react-query

swr https://swr.vercel.app/

他们可以管理你获取的数据并为你存储,如果他们有你的数据,它会返回你数据的缓存实例

更新:

如果您想在重新加载页面后保存数据,可以使用两个有用库,它们可以将状态保存到localStorage

对于yo可以使用的简单状态:

use-persisted-state https://www.npmjs.com/package/use-persisted-state

对于复杂的状态,可以使用:

use-persisted-reducer

https://github.com/khakestani/use-persisted-reducer

https://www.npmjs.com/package/use-persisted-reducer

票数 2
EN

Stack Overflow用户

发布于 2020-10-17 12:44:44

我能想到两种方法-

  1. 使用高阶组件或渲染属性模式。这将把API调用逻辑提取到单个位置,然后您可以包装组件以获取数据。有关更多信息,您可以在文档https://reactjs.org/docs/higher-order-components.html

中挖掘

  1. 使用Redux和thunk来利用存储和操作。你可以在这里找到redux文档https://redux.js.org
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64399034

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档