首页 > 其他 > 详细

react之state

时间:2019-10-18 17:35:34      阅读:56      评论:0      收藏:0      [点我收藏+]

1、不要直接修改 State

例如,此代码不会重新渲染组件:

技术分享图片

而是应该使用 setState():

技术分享图片

构造函数是唯一可以给 this.state 赋值的地方

2、State 的更新可能是异步的

出于性能考虑,React 可能会把多个 setState() 调用合并成一个调用。

因为 this.props 和 this.state 可能会异步更新,所以你不要依赖他们的值来更新下一个状态。

例如,此代码可能会无法更新计数器:

技术分享图片

 要解决这个问题,可以让 setState() 接收一个函数而不是一个对象。这个函数用上一个 state 作为第一个参数,将此次更新被应用时的 props 做为第二个参数

技术分享图片

 上面使用了箭头函数,不过使用普通的函数也同样可以:

技术分享图片

 3、State 的更新会被合并

当你调用 setState() 的时候,React 会把你提供的对象合并到当前的 state。

例如,你的 state 包含几个独立的变量:

技术分享图片

 然后你可以分别调用 setState() 来单独地更新它们:

技术分享图片

 这里的合并是浅合并,所以 this.setState({comments}) 完整保留了 this.state.posts, 但是完全替换了 this.state.comments

react之state

原文:https://www.cnblogs.com/meek/p/11699571.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!