我正在尝试从数组中的每个对象中删除这2个属性,但是该属性不起作用。每个对象都在数组内部。我的意思是主数组包含对象数组。有没有一种简单的方法可以解决此问题,而无需两次使用map()?以及在这种情况下如何返回主要的修改数组?
const modifiedItems = this.items.map(item => {
delete item.created,
delete item.removed
return item
})
数据如下:
this.items = [
[{ removed: 1, created: 1, a:2, b: 2, c: 3}]
[{ removed: 1, created: 1, a:2, b: 2, c: 3}, { removed: 1, created: 1, a:2, b: 2, c: 3},]
];
上面的代码不起作用,因为它没有映射到主数组中的数组。如何最好地从位于主数组中的所有数组的每个对象中删除这些属性?
答案 0 :(得分:4)
为什么不删除而不是删除不具有要删除属性的对象。
您可以解构要删除的属性,然后使用rest parameters语法将其他属性收集到变量中。之后,您只需要返回包含除您要删除的属性之外的所有属性的变量即可。
const modifiedItems = this.items.map(
({ created, removed, ...rest }) => rest
);
以下代码段显示了一个示例:
const arr = [
{ removed: 1, created: 1, a:2, b: 2, c: 3},
{ removed: 1, created: 1, a:2, b: 2, c: 3},
{ removed: 1, created: 1, a:2, b: 2, c: 3},
];
const modifiedItems = arr.map(
({ created, removed, ...rest }) => rest
);
console.log(modifiedItems);
在您的情况下,this.items
是一个包含嵌套数组的数组。因此,要从嵌套数组内部的对象中删除属性,您还需要映射每个嵌套数组。
以下代码段显示了一个示例:
const items = [
[ { removed: 1, created: 1, a: 2, b: 2, c: 3 } ],
[
{ removed: 1, created: 1, a: 2, b: 2, c: 3 },
{ removed: 1, created: 1, a: 2, b: 2, c: 3}
]
];
const modifiedItems = items.map(subArr => {
return subArr.map(({ created, removed, ...rest }) => rest)
});
console.log(modifiedItems);