您现在的位置是:首页 > 文章详情

React中setState修改深层对象

日期:2018-11-11点击:451
在React中经常会使用到setState,因为在react生态中,state就是一切.在开发过程中,时长会在state中遇到一些比较复杂的数据结构,类似下面这样的:
state = { list: { objA: { name: 'A', age: 20 }, objB: { name: 'B', age: 25 }, objC: { show: false }, objD: 'D' } }

这时需要我们修改listobjA中的name属性和objD的属性,遇到这样的情况我们一般会使用什么办法解决呢?其实有三种解决方案:

方案一(作用于对象中的深层级和第一层级):

 this.setState({ list: { ...this.state.list, objA: { ...this.state.list.objA, name: 'A1' } } })

方案二(作用对象中的第一层级):

 let data = Object.assign({}, this.state.list, {objD: 'D1'}) this.setState({ list: data })

方案三(作用于对象中的深层级和第一层级):

 let data = this.state.list; data.objA.name = 'A1'; data.objD = 'D1'; this.setState({ list: data })

总结:

| 方案 | 适用范围 | 缺点
| :-: | :-: | :-: |
| 方案一 |多层级和单一层级都存在 | 写法麻烦,单次对象赋值,对象层级多的时候,容易遗漏
| 方案二 |只适用与第一层级 | 只适用第一层级
| 方案三 |多层级和单一层级都存在 | 若存在深层及和单一层级的,需要多次赋值

这三种写法都可以,使用哪一种方案,还需要根据业务来定.希望看了之后,能给大家带来一些帮助,谢谢.
原文链接:https://yq.aliyun.com/articles/667986
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章