繁体   English   中英

如何从文字对象数组中删除元素

[英]How to remove an element from array of literal objects

您好,我正在尝试从数组数据中的每个对象中删除操作属性:

[{productName: "", ... action: ...,}, {productName: "", ...action:...} ...]
var arr  =[{productName: "bbbb", action: 'b'},
         {productName: "aa",action: 'a'}, 
         {productName: "tt",action: 't'}, 
         {productName: "vv",action: 'v'}]


arr = arr.map((d) => {delete d.action ; return d;});

1) 使用map(...)

your_array.map(o => {'productName': o.productName})

请注意,如果您想过滤掉许多属性,这会更优雅,但如果您只想删除一个属性,则需要做更多的工作。

2) delete

for (let i = 0; i < your_array.length; i++){
    delete your_array[i].action
}

使用map遍历数组并解构对象以仅保留所需字段

 var arr = [{ producet: 'xyz', action: 'abc', other: 'o' }, { producet: 'xyz', action: '123', other: 'o' }, { producet: 'xyz', action: 'sdf', other: 'o' }] const result = arr.map(({ action, ...rest }) => rest); console.log(result);

在 ES6 中,您可以使用带有解构休息参数的map来分离您想要保留的对象属性和您想要丢弃的部分:

 const data = [{ id: 1, productName: "1", action: '' }, { id: 1, productName: "2", action: '' }]; let out = data.map(({ action, ...rest }) => rest); console.log(out);

使用数组map它将返回一个新数组。内部map回调创建一个新对象并仅填充那些必需的字段。 不要改变原始数组

 var arr = [{ productName: "1", action: '' }, { productName: "2", action: '' }]; let newArr = arr.map(function(item) { return Object.assign({}, { productName: item.productName }) }); console.log(newArr)

根据文档,您可以使用delete运算符。

一个简单的方法是循环遍历数组arr并从每个对象中删除属性。

for (var i = 0; i < arr.length; i++){
    delete arr[i].action;
}

这种方法比其他方法(例如mapfor each )略快

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM