- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我将此行视为对此处另一个问题的回答:
“componentWillMount 应该是 componentDidMount,否则你会在节点中泄漏事件发射器。”
我也不是很懂。有人可以更详细地解释一下吗?
更多信息:
使用 flux 构建一个 React 应用程序,作为初始渲染的一部分,子组件计算一些数据。理想情况下,在计算完这些数据后,我想调用一个操作,用一部分新数据更新商店的状态。
通常,更新商店的状态会发出一个导致重新渲染的更改事件。但是,由于直到 componentDidMount(而不是在 componentWillMount 中)才添加更改监听器,因此我的顶级组件无法监听初始渲染期间发生的更改并启动重新渲染。
如果我将 addChangeListener 移动到 componentWillMount 似乎可以解决这个问题,但上面的引述表明这是个坏主意?
最佳答案
我认为应该在 componentDidMount
中设置监听器的流行观点是错误的,因为它可以防止同构应用程序出现问题。我认为在 98% 的情况下,对于非同构应用程序,在 componentWillMount
和 componentDidMount
中设置监听器将以相同的方式工作,但它在概念上是错误的,并且在 2% 的情况下例(如原题给出的例子)会做错事。
React 源代码中有 git issue 讨论和评论,建议最好不要在服务器上调用 componentWillMount
,但如果不是,则会产生问题在校验和测试中比较服务器预渲染和客户端初始渲染。在服务器上拥有 componentWillMount
意味着在这种情况下它不会作为组件生命周期的一部分执行,但这被用作在任何情况下都不将其视为生命周期一部分的借口。
事实上,如果您不创建同构应用程序,componentWillMount
正是注册监听器的正确位置。如果您正在创建一个同构应用程序,那么您必须做出一些妥协,因为在这种情况下校验和/生命周期问题并不理想(也许只是测试服务器环境,然后不注册监听器?)。
在非同构应用程序中,在 componentWillMount
中添加监听器在某些情况下可以节省不必要的重新渲染,并将按文档顺序注册它们。文档顺序的优点是,如果您有办法在重新呈现组件时刷新未决事件(例如,MutationObserver
上的takeRecords
),那么您可以确保文档自上而下而不是自下而上重新渲染,将渲染复杂度从多项式转换为线性。
此外,在初始渲染和注册监听器之间没有危险期,Store 可以在不触发渲染的情况下更改,从而导致 View 与 Store 不同步(原始问题中给出的示例问题).如果监听器已在 componentDidMount
中注册,您需要确保商店在子级的 componentDidMount
调用中未更改,或者强制重新渲染/重新同步注册监听器后,如果在 componentDidMount
中完成,则以反向文档顺序完成,这可能是多项式复杂度(取决于 React setStates
的聚合方式/是否聚合)。
关于javascript - 为什么 addChangeListener 应该在 componentDidMount 而不是 componentWillMount?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30898571/
我正在尝试在Elasticsearch中返回的值中考虑地理位置的接近性。我希望近距离比某些字段(例如legal_name)重要,但比其他字段重要。 从文档看来,当前的方法是使用distance_fea
我是Elasticsearch的初学者,今天在进行“多与或”查询时遇到问题。 我有一个SQL查询,需要在Elastic中进行转换: WHERE host_id = 999 AND psh_pid =
智能指针应该/可以在函数中通过引用传递吗? 即: void foo(const std::weak_ptr& x) 最佳答案 当然你可以通过const&传递一个智能指针。 这样做也是有原因的: 如果接
我想执行与以下MYSQL查询等效的查询 SELECT http_user, http_req_method, dst dst_port count(*) as total FROM my_table
我用这两个查询进行测试 用must查询 { "size": 200, "from": 0, "query": { "bool": { "must": [ { "mat
我仍在研究 Pro Android 2 的简短服务示例(第 304 页)同样,服务示例由两个类组成:如下所示的 BackgroundService.java 和如下所示的 MainActivity.j
给定标记 like this : header really_wide_table..........................................
根据 shouldJS 上的文档网站我应该能够做到这一点: ''.should.be.empty(); ChaiJS网站没有使用 should 语法的示例,但它列出了 expect 并且上面的示例似乎
我在 Stack Overflow 上读到一些 C 函数是“过时的”或“应该避免”。你能给我一些这种功能的例子以及原因吗? 这些功能有哪些替代方案? 我们可以安全地使用它们 - 有什么好的做法吗? 最
在 C++11 中,可变参数模板允许使用任意数量的参数和省略号运算符 ... 调用函数。允许该可变参数函数对每个参数做一些事情,即使每个参数的事情不是一样的: template void dummy(
我在我从事的项目之一上将Shoulda与Test::Unit结合使用。我遇到的问题是我最近更改了此设置: class MyModel :update end 以前,我的(通过)测试看起来像这样: c
我该如何做 or使用 chai.should 进行测试? 例如就像是 total.should.equal(4).or.equal(5) 或者 total.should.equal.any(4,5)
如果您要将存储库 B 中的更改 merge 到存储库 A 中,是否应该 merge .hgtags 中的更改? 存储库 B 可能具有 A 中没有的标签 1.01、1.02、1.03。为什么要将这些 m
我正在尝试执行X AND(y OR z)的查询 我需要获得该代理为上市代理或卖方的所有已售属性(property)。 我只用 bool(boolean) 值就可以得到9324个结果。当我添加 bool
我要离开 this教程,尝试使用 Mocha、Supertest 和 Should.js 进行测试。 我有以下基本测试来通过 PUT 创建用户接受 header 中数据的端点。 describe('U
我正在尝试为 Web 应用程序编写一些 UI 测试,但有一些复杂的问题希望您能帮助我解决。 首先,该应用程序有两种模式。其中一种模式是“训练”,另一种是“现场”。在实时模式下,数据直接从我们的数据库中
我有一个规范: require 'spec_helper' # hmm... I need to include it here because if I include it inside desc
我正在尝试用这个测试我在 Rails 中的更新操作: context "on PUT to :update" do setup do @countdown = Factory(:count
我还没有找到合适的答案: onclick="..." 中是否应该转义 &(& 符号)? (或者就此而言,在每个 HTML 属性中?) 我已经尝试在 jsFiddle 和 W3C 的验证器上运行转义和非
import java.applet.*; import java.awt.*; import java.awt.event.*; public class Main extends Applet i
我是一名优秀的程序员,十分优秀!