首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何在循环中调用SetState时合并对象

如何在循环中调用SetState时合并对象
EN

Stack Overflow用户
提问于 2020-08-14 17:36:05
回答 3查看 56关注 0票数 1

在我的组件中,我有一个如下所示的状态:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  class MainClass 

  constructor(props) {
    super(props);
    this.state = {
      form: {
        startDate:"1/11/2020", 
        endDate:"5/11/2020", 
        ....
     },
    };
  }

我有一个更新开始和结束日期的函数,还有一个更新表单的函数

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  handleFormChanges = targets => {
    targets.forEach(function (target) {
      this.setState({
        form: { ...this.state.form, [target.name]: target.value },
      });     
     });
  };
  

..... 


updateDate(startDate, endDate) {
const newStartDate = {name:"startDate", value:startDate.value}
const newEndDate = {name:"endDate", value:endDate.value}
this.handleFormChanges([newStartDate, newEndDate])
}  

所以我意识到在循环中调用setState是一种代码气味,而不是react是如何工作的。如何组合目标数组,以便只需调用setState一次?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-08-14 17:42:10

您可以使用reduce一次性累积targets

编辑:要同时处理单个对象和对象数组,可以用方括号[]包装targets,然后用flat()包装

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
this.setState({
  form: {
    ...this.state.form,
    ...[targets].flat().reduce(
      (acc, target) => ({ ...acc, [target.name]: target.value }),
      {}
    ),
  },
})
票数 2
EN

Stack Overflow用户

发布于 2020-08-14 17:41:52

你可以拥有像这样的东西

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const newObj={};
 targets.forEach(function (target) {
 
        newObj[target.name]=target.value,
       
     });
this.setState({...this.state.form,...newObj})

票数 0
EN

Stack Overflow用户

发布于 2020-08-14 17:46:57

这绝对是一个错误的想法,因为你可能会错过一些数据,并在每次迭代中导致额外的渲染。

主要思想是每个函数使用一次setState。此外,您也不需要使用handleFormChanges,更好的做法是按键添加值)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
updateDate(startDate, endDate) {

 this.setState({
        form: { 
        ...this.state.form, 
       "startDate": startDate.value,
        endDate: endDate.value
          },
      });    
}  
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63417566

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文