我有一个应用程序正在使用mobx-state-tree
,目前有一些简单的商店:
Article
表示一篇文章,可以是通过第 3 方 API 获取的,也可以是内部编写的ArticleStore
包含对文章的引用:{ articles: {}, isLoading: bool }
简单场景
此设置适用于简单的用例,例如基于 ID 获取文章。例如
- 用户导航到
/article/{articleUri}
articleStoreInstance.fetch([articleUri])
返回有问题的文章- ID 在渲染函数中获取,并使用
articleStoreInstance.articles.get(articleUri)
复杂场景
对于更复杂的场景,如果我想根据复杂的查询获取一组文章,例如{ offset: 100, limit: 100, freeTextQuery: 'Trump' }
,我应该:
- 拥有一个全球
SearchResult
商店,仅链接到用户搜索过的文章 - 实例化一个一次性
SearchResult
存储,只要我需要它就可以传递? - 将查询和一般 UI 状态完全排除在商店之外?
我应该补充一点,我想在页面加载之间将文章保留在商店中,以避免一遍又一遍地重新获取相同的内容。
是否有某种标准化的方法来解决这个问题?有什么例子可以看吗?