奇怪的 bug。setState 更新 state 之后并没有重新 render 出来正确的值。

2018-05-10 11:07:00 +08:00
 lbfeng

Link: https://gitlab.com/alex1007/react-test.git

input 里输入名字或者邮箱返回 match 的结果。前几个返回的值即使在 setState 之后也不会消失。

https://gitlab.com/alex1007/react-test/raw/master/shot.png

4348 次点击
所在节点    React
3 条回复
maichael
2018-05-10 11:27:57 +08:00
你的 Contact 子组件写的有问题,直接取 props 就好,为什么存到 state 里。

子组件的 state 从来没变过。
lbfeng
2018-05-11 23:20:49 +08:00
@maichael 因为要高亮 keyword 所以还是需要在 constructor 里初始化。getDerivedStateFromProps 解决了 bug

https://stackoverflow.com/questions/41233458/react-child-component-not-updating-after-parent-state-change?utm_medium=organic&utm_source=google_rich_qa&utm_campaign=google_rich_qa

const contacts = this.state.result.map((contact, i) =>
<Contact contact={contact} key={i} keyword={this.state.query} />);
console.log(contacts);

我的问题是 contacts 这个 array 已经变了,问什么还是有之前的会显示。
lbfeng
2018-05-11 23:26:42 +08:00
@maichael 我知道了,一开始有 array 里有 1000 个值,有 1000 个 Contact 被 mount,keyword 变化时 array 的长度变了。多余的被 unmount,剩下的不变,虽然的有新的 props 但因为没有 getDerivedStateFromProps,所以也没被更新。不知道想的对不对。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/453694

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX