我想从数组中的每个对象中删除坏属性。有没有比使用for循环并从每个对象中删除它更好的方法呢?

var array = [{"bad": "something", "good":"something"},{"bad":"something", "good":"something"},...];

for (var i = 0, len = array.length; i < len; i++) {
  delete array[i].bad;
}

似乎应该有一种方法来使用原型之类的。我不知道。想法吗?


当前回答

数组var =[{“坏”:“东西”,“好”:“东西”},{“坏”:“东西”,“好”:“东西”}); const cleanArray = array.map(item=>{ 删除item.bad 返回项目 }) console.log (cleanArray)

其他回答

ES6:

const newArray = array.map(({keepAttr1, keepAttr2}) => ({keepAttr1, newPropName: keepAttr2}))

在我看来,这是最简单的变体

array.map(({good}) => ({good}))

这对我来说很有效!

export function removePropertiesFromArrayOfObjects(arr = [], properties = []) {
return arr.map(i => {
    const newItem = {}
    Object.keys(i).map(key => {
        if (properties.includes(key)) { newItem[key] = i[key] }
    })
    return newItem
})
}

其他唯一的方法是表面上的,实际上是循环。

例如:

array.forEach(function(v){ delete v.bad });

注:

如果你想要兼容IE8,你需要为forEach准备一个垫片。正如你提到的prototype, prototype.js也有一个垫片。 删除是最糟糕的“优化杀手”之一。使用它通常会破坏应用程序的性能。如果你真的想要删除一个属性,你无法避免它,但你通常可以将属性设置为undefined,或者只是构建不带属性的新对象。

只有当你的对象相似时,使用原型的解决方案才有可能:

function Cons(g) { this.good = g; }
Cons.prototype.bad = "something common";
var array = [new Cons("something 1"), new Cons("something 2"), …];

但它很简单(和O(1)):

delete Cons.prototype.bad;