繁体   English   中英

QueryRenderer在Relay Modern中的作用?

[英]Role of QueryRenderer in Relay Modern?

所以,首先是一些背景知识 我是一名原生的iOS / Android开发人员,现在正在开始我的第一个React Native项目。 它带来了Javascript的所有好处和痛苦,但到目前为止我非常喜欢它:-)我还决定第一次尝试使用GraphQL。

作为一般的React环境的新手,我也没有任何关于Relay的先验知识,但是在我的创业社区的朋友和我的web-dev同事的推荐下选择了它。 我也被警告过一个有点陡峭的学习曲线,但无论如何我决定继续 - 我已经在与JS和一个新的移动平台的0.xx版本进行一场艰苦的战斗,所以到底是什么,对吧? :-)我设法正确地设置了我的项目并用QueryRenderer了我的GQL服务器,这是一个很大的安慰:-)

所以,关于问题

我很难搞清楚容器/组件的关系,以及一般的容器组成。 阅读关于作文的文档有所帮助,但我对QueryRenderer的作用仍有疑问

  • QueryRenderer被docs称为每个Relay树的根容器。 这是否意味着应该在我们的应用程序中为root创建一个QueryRenderer 或者在每个导航路径的根目录(即我们的应用程序中的选项卡)? 或者仅针对每个容器组件(与表示/哑/纯组件相反,React明智)? 请注意,我不是在寻找意见,而是寻求最佳实践:-)
  • FragmentContainer (或任何其他容器)可以在“父”组件中没有QueryRenderer情况下工作吗?
  • QueryRenderer如何链接到子容器? 它是否获取子容器所需的所有数据的总和,然后从缓存中读取子容器,或者? 如果是这样,我误解了Relay的优点 - 我们认为每个组件都可以独立于其他所有组件检索数据,并且每个组件都不了解其他组件(包括父/子组件)的数据要求)。 我认为这个假设也让我对QueryRenderer ,并且需要一个“Root”容器。
  • 如果QueryRenderer是中继树的“父”/“根”中继容器,那么它如何根据它的请求呈现视图组件呢? 为什么它必须有一个请求? 何时以及我们应该使用QueryRenderer

任何帮助深表感谢 :-)

感谢您提出这个话题。 我也刚刚使用ReactNative进入Relay,并获得了一些令人兴奋的结果。

首先,我很惊讶将用于反映GraphQL数据库的UI组件带到屏幕上是多么容易。 在学习了JavaScript和反应原生流水线的基础知识的最初开销之后,Relay已经成为一种呈现数据的绝佳方式。

关于最佳实践,我无法确定如何呈现您的QueryRenderer和fragmentContainer,但是我可以描述我们呈现数据的方式。

首先,我们创建一个反应导航堆栈和选项卡。 在每个主屏幕内,我们运行QueryRenderer。 然后在该QueryRenderer中,对于每个特定的UI组件,我们分成一个fragmentContainer。

  • 导航流程(反应导航,堆栈/标签导航器)
  • 屏幕(QueryRenderer)UI
  • 小部件/组件(fragmentContainer)

这允许我们为屏幕创建所需的主要查询,然后拆分组件数据以适应易于由其所代表的GraphQL查询片段定义的可消耗组件。 但是,这确实意味着我们在应用程序中运行多个查询而没有中央帐户查询将整个呈现包装成一个整洁的包。

理想情况下,我想在导航器的顶部尝试一个QueryRenderer,但是我还没有完全了解如何以及如果这可以工作,因为Navigators不响应render()函数,这是QueryRenderer所在的位置需要。

我也有兴趣听听其他人如何在可导航的本地应用中应用中继的方法。

因此,在使用我们的应用程序进行了更多工作之后,我想我会回来发布关于我们迄今为止的想法和经验,希望它可以帮助某人。

在@Peter Suwara的伟大帖子的基础上,我们最初达成了类似的策略

  • 有一个根/父导航树
  • 对于树中的每个屏幕,将QueryRenderer作为其包含的所有表示/哑元组件的根
  • 使用片段在子组件中声明数据依赖性

就像我们在下面的评论中讨论他的答案一样,这种方法可能并不总是最好的。 在内部进一步讨论之后,我们得出的结论是,由于以下几个原因,有太多案例可能没有意义:

  • 如果您为每个屏幕加载检索数据,通常会有更多的往返次数。 您希望将app-flow考虑在内,并获取尽可能多的数据,以及路由及其子项所需的数据。
  • 此外,如果您在同一QueryRenderer上检索屏幕的子组件的所有数据,您有时可能最终会获取永远不会向用户显示的数据(即很少显示的详细信息视图的详细信息或类似情况) 。

经过一番思考和讨论后,我们想出了这个经验法则,以便何时创建一个Relay树的新QueryRenderer“root”:

无论何时需要新的错误处理策略,都要创建一个新的QueryRenderer

这是因为非常实际的原因,它是您处理数据错误/加载的唯一机会,但它对用户流和组合的方式也有意义,因为通常两个事情发生冲突 - 你想要一个新的当您到达应用程序的新“流程”/部分时处理网络错误的方法。 也许Facebook的一些聪明人在我们面前想到了这一点? :-)

与所有经验法则一样,它只是 - 指南,而不是规则,当然也有例外。 然而,它似乎对我们内部有意义 - 至少目前如此。

关于这些想法的任何和所有反馈都是非常受欢迎的,因为我认为官方文档至少可以说是乏善可陈的,因此社区讨论是我们所有的,直到文档和一般模式随着时间的推移而解决。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM