javascript根据键值查找并删除数组中的对象

时间:2014-02-09 13:54:03

标签: javascript jquery arrays object

我一直在尝试几种方法来查找数组中的对象,其中ID = var,如果找到,则从数组中删除对象并返回新的对象数组。

数据:

[
    {"id":"88","name":"Lets go testing"},
    {"id":"99","name":"Have fun boys and girls"},
    {"id":"108","name":"You are awesome!"}
]

我可以使用jQuery $ grep;

搜索数组
var id = 88;

var result = $.grep(data, function(e){ 
     return e.id == id; 
});

但是如何在id == 88时删除整个对象,并返回如下数据:

数据:

[
    {"id":"99","name":"Have fun boys and girls"},
    {"id":"108","name":"You are awesome!"}
]

14 个答案:

答案 0 :(得分:126)

  

我可以为数组grep数组,但是如何删除id == 88

的整个对象?

只需按相反的谓词过滤:

var data = $.grep(data, function(e){ 
     return e.id != id; 
});

答案 1 :(得分:93)

如果您不使用jquery,

这是一个解决方案:

myArray = myArray.filter(function( obj ) {
  return obj.id !== id;
});

答案 2 :(得分:78)

你可以简化这个,而且这里真的不需要使用jquery。

var id = 88;

for(var i = 0; i < data.length; i++) {
    if(data[i].id == id) {
        data.splice(i, 1);
        break;
    }
}

只需遍历列表,找到匹配的id,拼接,然后中断退出循环

答案 3 :(得分:10)

使用findIndex和数组传播运算符在ES6 / 2015中有一种新方法:

const index = data.findIndex(obj => obj.id === id);
const newData = [
    ...data.slice(0, index),
    ...data.slice(index + 1)
]

您可以将其转换为一个函数,以便以后重复使用,如下所示:

function remove(array, key, value) {
    const index = array.findIndex(obj => obj[key] === value);
    return index >= 0 ? [
        ...array.slice(0, index),
        ...array.slice(index + 1)
    ] : array;
}

这样您就可以使用一种方法通过不同的键删除项目(如果没有符合条件的对象,则返回原始数组):

const newData = remove(data, "id", "88");
const newData2 = remove(data, "name", "You are awesome!");

或者你可以把它放在你的Array.prototype上:

Array.prototype.remove = function (key, value) {
    const index = this.findIndex(obj => obj[key] === value);
    return index >= 0 ? [
        ...this.slice(0, index),
        ...this.slice(index + 1)
    ] : this;
};

并以这种方式使用它:

const newData = data.remove("id", "88");
const newData2 = data.remove("name", "You are awesome!");

答案 4 :(得分:8)

假设id是唯一的,你只需删除一个元素splice应该做的诀窍:

var data = [
{"id":"88","name":"Lets go testing"},
{"id":"99","name":"Have fun boys and girls"},
{"id":"108","name":"You are awesome!"}
],
id = 88;

console.table(data);

$.each(data, function(i, el){
    if (this.id == id){
        data.splice(i, 1);
    }
});

console.table(data);

答案 5 :(得分:4)

也许您正在寻找$.grep()功能:

arr = [
  {"id":"88","name":"Lets go testing"},
  {"id":"99","name":"Have fun boys and girls"},
  {"id":"108","name":"You are awesome!"}
];

id = 88;
arr = $.grep(arr, function(data, index) {
   return data.id != id
});

答案 6 :(得分:3)

var items = [
  {"id":"88","name":"Lets go testing"},
  {"id":"99","name":"Have fun boys and girls"},
  {"id":"108","name":"You are awesome!"}
];

如果您使用的是jQuery,请使用jQuery.grep,如下所示:

items = $.grep(items, function(item) { 
  return item.id !== '88';
});
// items => [{ id: "99" }, { id: "108" }]

使用ES5 Array.prototype.filter

items = items.filter(function(item) { 
  return item.id !== '88'; 
});
// items => [{ id: "99" }, { id: "108" }]

答案 7 :(得分:3)

sift是一个功能强大的集合过滤器,适用于此类操作和更高级的操作。它在node.js中的浏览器或服务器端的客户端工作。

var collection = [
    {"id":"88","name":"Lets go testing"},
    {"id":"99","name":"Have fun boys and girls"},
    {"id":"108","name":"You are awesome!"}
];
var sifted = sift({id: {$not: 88}}, collection);

它支持$in$nin$exists$gte$gt$lte$lt,{ {1}},$eq$ne$mod$all$and$or$nor,{{1 }},$not$size,并努力与MongoDB集合过滤API兼容。

答案 8 :(得分:3)

原生 ES6 解决方案:

const pos = data.findIndex(el => el.id === ID_TO_REMOVE);
if (pos >= 0)
    data.splice(pos, 1);

如果您确定该元素在数组中:

data.splice(data.findIndex(el => el.id === ID_TO_REMOVE), 1);

原型:

Array.prototype.removeByProp = function(prop,val) {
    const pos = this.findIndex(x => x[prop] === val);
    if (pos >= 0)
        return this.splice(pos, 1);
};

// usage:
ar.removeByProp('id', ID_TO_REMOVE);

http://jsfiddle.net/oriadam/72kgprw5/

注意:这会就地删除项目。如果您需要一个新数组,请使用之前答案中提到的 filter

答案 9 :(得分:2)

Array.prototype.removeAt = function(id) {
    for (var item in this) {
        if (this[item].id == id) {
            this.splice(item, 1);
            return true;
        }
    }
    return false;
}

这应该可以解决问题jsfiddle

答案 10 :(得分:1)

A同意答案,这是一种简单的方法,如果您想通过id查找并反对并删除它,就像下面的代码一样。

   var obj = JSON.parse(data);
   var newObj = obj.filter(item=>item.Id!=88);
       

答案 11 :(得分:0)

如果测试严格相等,请确保将对象id强制转换为整数:

var result = $.grep(data, function(e, i) { 
  return +e.id !== id;
});

Demo

答案 12 :(得分:0)

如果使用下划线js,则很容易根据键删除对象。 http://underscorejs.org。 例如:

  var temp1=[{id:1,name:"safeer"},  //temp array
             {id:2,name:"jon"},
             {id:3,name:"James"},
             {id:4,name:"deepak"},
             {id:5,name:"ajmal"}];

  var id = _.pluck(temp1,'id'); //get id array from temp1
  var ids=[2,5,10];             //ids to be removed
  var bool_ids=[];
  _.each(ids,function(val){
     bool_ids[val]=true;
  });
  _.filter(temp1,function(val){
     return !bool_ids[val.id];
  });

答案 13 :(得分:0)

const data = [
    {"id":"88","name":"Lets go testing"},
    {"id":"99","name":"Have fun boys and girls"},
    {"id":"108","name":"You are awesome!"}
];

这里我们得到id值为“88”的对象的索引

const index = data.findIndex(item => item.id === "88");
console.log(index); // 0

我们使用 splice 函数从数据数组中移除指定的对象

data.splice(index,1);
console.log(data); // [{"id":"99","name":"Have fun boys and girls"},{"id":"108","name":"You are awesome!"}]