更新嵌套对象的反应状态数组
Update react State array of nested objects
也许这很愚蠢,但我的状态是一个嵌套对象数组:o
看起来如下:
const data = [
{
randomid1: {
name: 'lorem',
latinName: 'ipsem',
},
},
{
randomid2: {
name: 'lorem2',
latinName: 'ipsem2',
},
},
]
我需要用其中一项的新名称 and/or latinName 更新此数组(假设 randomid1.name .
我一直在努力传播等,但不断出错。现在我正在尝试映射某些东西,但这也行不通。有人吗?
您可以使用 Array#find
and Object#hasOwnProperty
:
检查数组是否包含某个项目
const
data = [
{ randomid1: { name: 'lorem', latinName: 'ipsem' } },
{ randomid2: { name: 'lorem2', latinName: 'ipsem2' } }
],
id = 'randomid2';
const elem = data.find(e => e.hasOwnProperty(id));
if(elem) {
elem[id].name = 'new name';
}
console.log(data);
我会这样做:
// will iterate on all the top level objects
for (const itemWrapper of data) {
// will iterate just once
for (const item of Object.values(itemWrapper)) {
if (item.name = 'whatever') {
// update item
}
}
}
您可以移动此功能并 return 找到该项目以获得更好的性能。
PS : 数据结构似乎有点难用,如果你能把它改成你正在搜索的索引的东西,那就太好了。
我认为已经提供的解决方案更好,但如果您想知道如何使用 map 实现,这里有一种方法:
const data = [
{ randomid1: { name: 'lorem', latinName: 'ipsem' } },
{ randomid2: { name: 'lorem2', latinName: 'ipsem2' } }
];
const id = 'randomid2';
const newdata2 = data.map((elt) => {
if (elt[id]) {
return {[id] : {...elt[id], name: "new Name"}};
}
return elt;
});
console.log(newdata2)
也许这很愚蠢,但我的状态是一个嵌套对象数组:o 看起来如下:
const data = [
{
randomid1: {
name: 'lorem',
latinName: 'ipsem',
},
},
{
randomid2: {
name: 'lorem2',
latinName: 'ipsem2',
},
},
]
我需要用其中一项的新名称 and/or latinName 更新此数组(假设 randomid1.name .
我一直在努力传播等,但不断出错。现在我正在尝试映射某些东西,但这也行不通。有人吗?
您可以使用 Array#find
and Object#hasOwnProperty
:
const
data = [
{ randomid1: { name: 'lorem', latinName: 'ipsem' } },
{ randomid2: { name: 'lorem2', latinName: 'ipsem2' } }
],
id = 'randomid2';
const elem = data.find(e => e.hasOwnProperty(id));
if(elem) {
elem[id].name = 'new name';
}
console.log(data);
我会这样做:
// will iterate on all the top level objects
for (const itemWrapper of data) {
// will iterate just once
for (const item of Object.values(itemWrapper)) {
if (item.name = 'whatever') {
// update item
}
}
}
您可以移动此功能并 return 找到该项目以获得更好的性能。
PS : 数据结构似乎有点难用,如果你能把它改成你正在搜索的索引的东西,那就太好了。
我认为已经提供的解决方案更好,但如果您想知道如何使用 map 实现,这里有一种方法:
const data = [
{ randomid1: { name: 'lorem', latinName: 'ipsem' } },
{ randomid2: { name: 'lorem2', latinName: 'ipsem2' } }
];
const id = 'randomid2';
const newdata2 = data.map((elt) => {
if (elt[id]) {
return {[id] : {...elt[id], name: "new Name"}};
}
return elt;
});
console.log(newdata2)