我想从数组中的每个对象中删除坏属性。有没有比使用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;
}

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


当前回答

在ES6中,你可以分解每个对象来创建一个没有命名属性的新对象:

const newArray = array.map(({dropAttr1, dropAttr2, ...keepAttrs}) => keepAttrs)

其他回答

我建议使用Object。在forEach()循环中赋值,以便对象被复制并且不会影响原始对象数组

var res = [];
array.forEach(function(item) { 
    var tempItem = Object.assign({}, item);
    delete tempItem.bad; 
    res.push(tempItem);
});
console.log(res);

如果你使用underscore.js:

var strippedRows = _.map(rows, function (row) {
    return _.omit(row, ['bad', 'anotherbad']);
});

你可以这样做,更可读,而不是期望提高,因为没有找到关键字:

data.map((datum) => {
  return {
    'id':datum.id,
    'title':datum.login
  }
});

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

例如:

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

注:

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

通过减少:

const newArray = oldArray.reduce((acc, curr) => {
  const { remove_one, remove_two, ...keep_data } = curr;
  acc.push(keep_data);
  return acc;
}, []);