如何从数组中删除具有给定属性的对象

How to remove an object with a given property from an array

本文关键字:属性 对象 数组 删除      更新时间:2023-09-26

我有一个包含如下多个对象的数组。如何删除包含特定值的完整对象

var cars=  [
{key: 'browser', label: 'Chrome'},
{key: 'browser', label: 'Firefox'},
{key: 'browser', label: 'Safari'}
];

例如,要删除的对象是那些包含标签chrome和safari的对象。

我遇到过一维值数组的例子,但这是一个对象数组。

您可以使用Array.prototype.filter只返回某些值或只排除某些值。

var cars =  [
  {key: 'browser', label: 'Chrome'},
  {key: 'browser', label: 'Firefox'},
  {key: 'browser', label: 'Safari'}
];
// Filter by only the thing you want
var firefoxOnly = cars.filter(function(item) {
  return item.label === 'Firefox';
});
console.log(firefoxOnly);
// filter out the things you don't want
var notChromeSafari  = cars.filter(function(item) {
  return item.label !== 'Chrome' && item.label !== 'Safari';
});
console.log(notChromeSafari);
// or make a set of exclusions to filter out things you don't want
// you could also make this a list of inclusions, 
// it would be the inverse of this. I'll leave that as an exercise for the reader.
var exclusions = ['Chrome', 'Safari'];
var filtered  = cars.filter(function(item) {
  // only return items that are not in the exclusion list
  return exclusions.indexOf(item.label) === -1;
});
console.log(filtered);

只需循环遍历数组,并通过检查属性是否为给定值来删除不需要的项。注意,您需要从last到first循环,以便每次迭代时索引都是正确的。

var cars=  [
    {key: 'browser', label: 'Chrome'},
    {key: 'browser', label: 'Firefox'},
    {key: 'browser', label: 'Safari'}
];
for(var i = cars.length -1; i >= 0 ; i--){
    if(cars.label == "Safari" || cars.label == "Chrome"){
        cars.splice(i, 1);
    }
}

可以使用数组筛选函数来实现。

var cars = [{
  key: 'browser',
  label: 'Chrome'
}, {
  key: 'browser',
  label: 'Firefox'
}, {
  key: 'browser',
  label: 'Safari'
}];
let removeKeys = ["Safari", "Chrome"];
let filteredArray = cars.filter((obj) => removeKeys.indexOf(obj.label) === -1);
console.log(filteredArray);

这个解决方案如何:

var cars=  [
 {key: 'browser', label: 'Chrome'},
 {key: 'browser', label: 'Firefox'},
 {key: 'browser', label: 'Safari'}
 ];
var arr = [];
for(var i = 0; i < cars.length; i++){
 if(cars[i].label !== 'Safari' && cars[i].label !== 'Chrome'){
  arr.push(cars[i]);
 }
}
console.log(arr);

首先需要找到要删除对象的标签的索引。

var cars= [ {key: 'browser', label: 'Chrome'}, {key: 'browser', label: 'Firefox'}, {key: 'browser', label: 'Safari'} ];
for(var i = 0; i < cars.length ; i++)
{ 
     if(cars.label == "Safari" || cars.label == "Chrome")
     { 
           delete cars[i].label
     }
}

这只会删除标签。如果你想删除整个元素,那么使用cars.splice(i, 1)