我用AXIOS创建了一个React。我需要从后端获取一些JSON数据,并使用该数据更改状态。当我得到对象并映射到我的状态时,状态只为对象的最后一个元素设置。因此,我只能看到状态中的最后一个元素。,我如何才能将所有的元素都状态化?
我的API调用如下
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数据:
{response :
{AllUsers :
0 : {name: "Amy", id: 1, email: "myEmail1"},
1 : {name: "Doris", id: 2, email: "myEmail2"},
2 : {name: "Jase", id: 3, email: "myEmail3"}
}
}我预计状态“数据”将设置如下:
data : [
createData("Amy",1,"myEmail1"),
createData("Doris",2,"myEmail2"),
createData("Jase",3,"myEmail3")
]但是在获取JSON数据之后的实际状态是
data : [
createData("Jase",3,"myEmail3")
]我怎么才能解决这个问题?
发布于 2019-03-21 06:26:24
您需要首先映射数据,然后设置整个状态。
API.post('viewallusers', [], config)
.then(({ data }) => {
this.setState({
data: data.response.AllUsers.map(user => (createData(user.name, user.id, user.email)))
})
})或者使用setState的回调版本并手动合并state.data (在这种情况下不推荐)
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)]})
)
})
})发布于 2019-03-21 06:19:21
这可能是因为setState没有执行深度合并。所以如果你在州里
state = {
key1: 123,
key2: {
test1: 1,
test2: 2
}
}而你却有
this.setState({
key2: {
test1: 4
}
})你最终会
state = {
key1: 123,
key2: {
test1: 4
}
} 你必须做的是:
this.setState((ps) => ({
key2: {
...ps.key2,
test1: 4
}
}));如果key2的值为数组,类似的方法也能工作。或者,您可以首先映射所有数据,然后按照其他答案中的建议执行setState。
https://stackoverflow.com/questions/55274646
复制相似问题