- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
随着 React Web 应用程序变得复杂,某些组件具有大量 props,这会降低可读性,更难以预期该组件的功能,并且添加大量 props 类型检查并将 props 从最顶部组件传递到底部非常繁琐。这主要是由传递 Flux/Redux 操作和从上到下传递的存储引起的。
有没有什么好方法可以减少传入的 props 数量?
我想到了两种解决方案,并不完美:
使用扩展运算符 {...props} 传递 props。这确实减少了编写大量 props 和 prop 类型检查,但命名可能会发生冲突,因此 actions/store 的名称应该是唯一的。另一个缺点是要格外小心传递或不传递哪些 Prop ,以避免副作用。
用一个容器包装组件,该容器以一种特殊的方式直接将操作/存储连接到组件。例如,react-redux
的connect()
可以使用。这比解决方案 #1 更干净、更简单,但如果组件包含容器,由于 Redux 错误,则很难编写组件测试。错误的一个示例是
Invariant Violation: Could not find "store" in either the context or props of "Connect(Header)". Either wrap the root component in a <Provider>, or explicitly pass "store" as a prop to "Connect(Header)".
最佳答案
您很好地描述了两种方法及其优缺点。我将在您所说的基础上添加一些设计注意事项。
方法#2 是我的首选方法。减少通过组件的 props 数量可以避免复杂性。有多种方法可以在不触发该错误的情况下测试组件,但说实话,我认为这值得有一个单独的 Stack Overflow 问题。现在,我只想说研究浅层渲染,并考虑您是否真的需要在这里进行单元测试与集成测试。如果您还将在 Selenium 等中创建自动化测试,那么这也许可以作为您的集成测试。
可以通过严格使用 PropTypes 来验证正在传递的内容来改进方法 #1。省略对仅传递 ...props 的中间组件的 PropTypes 检查是合理的,但最终组件(实际使用 props 而不是仅传递的组件)应该具有非常严格的 PropTypes 声明。使用形状而不是对象。使用 ArrayOf 而不是 Array,并且基本上利用所有机会在 PropTypes 声明中进行具体说明。
关于您对名称冲突的担忧,有时将 Prop 分组为一个对象的成员并将该对象作为单个 Prop 传递会有所帮助。如果这些 props 在概念上是相关的或者有一个单一的目标组件,那么这是有道理的。我仍然非常喜欢拥有更多的容器组件(方法#2),因为它会导致更少的信息流过 props。为具有嵌套成员的对象编写良好的 PropType 需要更多时间,并且会产生警告消息,从而需要更长的时间来进行故障排除。
人们有时会在开始使用 Redux/Flux 后忘记 .state,一些纯粹主义者更喜欢通过商店发送和接收所有内容。无状态组件声明的优雅进一步使我对向组件添加 .state 产生偏见。但 .state 非常适合跟踪动画和工具提示可见性等短暂的事物。并非所有东西都需要在商店中并通过 Prop 传递。
关于reactjs - 如何减少传入的react props数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44033704/
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: How do I copy an object in Java? 我的类中有一个函数 Claus它调用一个函数来接受
任何人都可以给我一个 linux 内核驱动程序手册或示例的链接,它可以修改来自/到指定 ip 端口的传入/传出数据包吗? 谢谢! 最佳答案 Kprobes 是一种可以做到这一点的方法。这是一个使用具有
我有一个 3rd 方网站,该网站具有发送到特定 url 的 webhook。我将其设置为发送到我网站上的空白页面(例如:www.mysite.com/webhook.php) 我在 webhook.p
我对传递的约定感到困惑*args在 super().__init__()在python继承中。 我了解需要使用关键字参数 **kwargs因此,如果需要,CRO 中的类可以采用所需的参数,但为什么还有
我有一个 webapi (.NET core 3.1) 方法,它正在获取 XML 并反序列化为对象。但是一些标签的开头和结尾是不一样的。例如,如果以 打开然后它以 关闭.因此 XML 格式不正确。
是否有一个 hg 命令可以组合 hg传入 + hg传出 + hg status? 这会告诉您是否有任何远程内容需要传入,是否有任何本地提交的内容需要出去,或者是否有任何本地更改需要提交。 最佳答案 虽
据我了解,你无法在两部 iPhone 之间建立连接(如果我错了,请纠正我)。因此,我想做的是在客户端应用程序之间放置一台服务器,该服务器接受消息并将其重新分发给适当的人员。本质上,该应用程序将允许人们
我正在使用 Apache Camel 向我的 Java 服务发送消息。我在消费者路线上保留了 transacted=true。我还需要发送有关成功处理 JMS 消息的电子邮件。 我正在使用以下代码来注
这个问题在这里已经有了答案: What does "this" point to? (5 个答案) 关闭 4 年前。 public class CommandForm extends Form im
我是一名 Swift 开发人员,也是 Dart 的新手。我正在尝试编写一些通用方法。 我想知道我是否可以在 Dart 中实现类似的事情。 //Swift version public func mod
基本上有人问我是否有任何方法可以捕获和下载通过邮件服务器的所有传入和传出电子邮件(最好是文本格式)。这种下载方法需要使用PHP或类似的服务器端语言来完成。 如果我能通过上述阶段,那么最终目标就很容易实
我正在学习 Flask 并且有一个关于动态路由的问题:是否可以传入一个可接受的路由列表?我注意到 any 转换器有潜力,但很难找到它的使用示例。基本上我有不同的端点组,它们应该在它们之间触发相同的 A
我正在学习如何使用 pthread 函数。在这里我想使用 pthread_create 创建一个线程并用它计算一些数字的平均值。(数字序列末尾的0表示已经完成) 这是我到目前为止写的: #includ
我需要传递一个带有字段“nombre”作为参数的条件 目前我这样做: @xcondicion= {:nombre.like => "%#{params[:qyBusqueda]}%"} cliente
我有以下两个 parseInt(),我不太清楚为什么它们会给我不同的结果: alert(parseInt(0.00001)) 显示 0; alert(parseInt(0.00000001)) 显示
我有一个使用 SODA 包来操作 JSON 数据库的 PL/SQL 处理程序。我想: 读取有效负载中键 id 的值 将负载 JSON 写入数据库中的新文档。 要执行第 1 步,处理程序将 :body
我正在使用 Oracle 试用 Dapper,我试图运行多结果集查询,但 Oracle 需要 dbtype 的 refcursor。 StringBuilder query = new StringB
我在将“工作表”选项卡重命名为任何文件名时遇到问题。这样做的问题是,如果用户意外下载工作表两次,Windows 会将 template(1).csv 附加到文件中,以保持其下载目录中的唯一性。在 Ex
我将 id 作为字符串传递到函数中。我想使用该 ID 来更改背景颜色。我用过: $("#"+address).css("background-color", "#3399FF"); 但它没有改变背景颜
我有一个 ListSourceAdapter.java 类, class ListSourceViewHolder extends RecyclerView.ViewHolder implements
我是一名优秀的程序员,十分优秀!