Ответ 1
Я могу grep массив для id, но как я могу удалить весь объект, где id == 88
Просто фильтруйте противоположный предикат:
var data = $.grep(data, function(e){
return e.id != id;
});
Я пытаюсь несколько подходов к тому, как найти объект в массиве, где 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!"}
]
Я могу grep массив для id, но как я могу удалить весь объект, где id == 88
Просто фильтруйте противоположный предикат:
var data = $.grep(data, function(e){
return e.id != id;
});
вот решение, если вы не используете jquery:
myArray = myArray.filter(function( obj ) {
return obj.id !== id;
});
Это можно упростить, и здесь нет необходимости использовать jquery.
var id = 88;
for(var i = 0; i < data.length; i++) {
if(data[i].id == id) {
data.splice(i, 1);
break;
}
}
Просто перебирайте список, найдите соответствующий идентификатор, сплайсинг, а затем перейдите, чтобы выйти из цикла
В ES6/2015 появился новый метод для этого с использованием findIndex и оператора распространения массива:
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!");
Предполагая, что идентификаторы уникальны, и вам нужно будет удалить только один элемент, 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);
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" }]
Возможно, вы ищете функцию $.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
});
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
, $eq
, $ne
, $mod
, $all
, $and
, $or
, $nor
, $not
, $size
, $type
и $regex
и стремится к API-совместимости с фильтрацией коллекции MongoDB.
Array.prototype.removeAt = function(id) {
for (var item in this) {
if (this[item].id == id) {
this.splice(item, 1);
return true;
}
}
return false;
}
Это должно сделать трюк, jsfiddle
Убедитесь, что вы обмениваете идентификатор объекта на целое число, если вы проверяете строгое равенство:
var result = $.grep(data, function(e, i) {
return +e.id !== id;
});
Если вы используете подчеркивание 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];
});