首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使JSON对象响应组件?

如何使JSON对象响应组件?
EN

Stack Overflow用户
提问于 2019-03-21 06:09:22
回答 2查看 55关注 0票数 0

我用AXIOS创建了一个React。我需要从后端获取一些JSON数据,并使用该数据更改状态。当我得到对象并映射到我的状态时,状态只为对象的最后一个元素设置。因此,我只能看到状态中的最后一个元素。,我如何才能将所有的元素都状态化?

我的API调用如下

代码语言:javascript
复制
API.post('viewallusers', [], config)
      .then(({ data }) => {
        const allUsers = data.response.AllUsers;
        allUsers
          .map(user => {
            return (
              this.setState({
                data: [
                  createData(
                    user.name,
                    user.id,
                    user.email
                  )
                ]
              })
            )
          })
      })
      .catch((err) => {
        console.log("AXIOS ERROR: ", err);
      })

JSON数据:

代码语言:javascript
复制
{response :
  {AllUsers :
    0 : {name: "Amy", id: 1, email: "myEmail1"},
    1 : {name: "Doris", id: 2, email: "myEmail2"},
    2 : {name: "Jase", id: 3, email: "myEmail3"}
  }
}

我预计状态“数据”将设置如下:

代码语言:javascript
复制
data : [
  createData("Amy",1,"myEmail1"),
  createData("Doris",2,"myEmail2"),
  createData("Jase",3,"myEmail3")
]

但是在获取JSON数据之后的实际状态是

代码语言:javascript
复制
data : [
  createData("Jase",3,"myEmail3")
]

我怎么才能解决这个问题?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-03-21 06:26:24

您需要首先映射数据,然后设置整个状态。

代码语言:javascript
复制
API.post('viewallusers', [], config)
  .then(({ data }) => {
    this.setState({
      data: data.response.AllUsers.map(user => (createData(user.name, user.id, user.email)))
    })
  })

或者使用setState的回调版本并手动合并state.data (在这种情况下不推荐)

代码语言:javascript
复制
API.post('viewallusers', [], config)
  .then(({ data }) => {
    data.response.AllUsers.forEach(user => {
      this.setState(prev =>
        ({...prev, data: [prev.data, createData(user.name, user.id, user.email)]})
      )
    })
  })
票数 1
EN

Stack Overflow用户

发布于 2019-03-21 06:19:21

这可能是因为setState没有执行深度合并。所以如果你在州里

代码语言:javascript
复制
state = {
    key1: 123,
    key2: {
        test1: 1,
        test2: 2

    }

}

而你却有

代码语言:javascript
复制
this.setState({
    key2: {
        test1: 4
    }

})

你最终会

代码语言:javascript
复制
state = {
    key1: 123,
    key2: {
        test1: 4
    }

} 

你必须做的是:

代码语言:javascript
复制
this.setState((ps) => ({
    key2: {
        ...ps.key2,
        test1: 4
    }

}));

如果key2的值为数组,类似的方法也能工作。或者,您可以首先映射所有数据,然后按照其他答案中的建议执行setState

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55274646

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档