javascript anahtar değerine göre dizideki nesneyi bul ve kaldır


139

Ben ID = var bir dizide bir nesne bulma ve bulunursa, nesneyi diziden kaldırmak ve nesnelerin yeni dizi dönmek nasıl çeşitli yaklaşımlar çalışıyorum.

Veri:

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

JQuery $ grep kullanarak dizi aramak mümkün;

var id = 88;

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

Ancak id == 88 olduğunda tüm nesneyi nasıl silebilirim ve şöyle verileri döndürebilirim:

Veri:

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

sliceİşlev ve küçük bir fordöngü kullanmaya ne dersiniz ?
Ahmed Hamdy

1
Tabii, ama, bu soruyu yazmamın nedeni, sıkıştığım için;) herhangi bir parçacık mı?
Tom

Bu
yazıyı

Başlık ve soru metni birbiriyle çelişiyor gibi görünüyor ... tamamen farklı iki yaklaşım öneriyor: A. öğeleri bir diziden B'ye karşı kaldırın . Yeni, filtrelenmiş bir dizi oluşturun.
canon

Yanıtlar:


155

Kimlik için dizi grep olabilir, ama id == 88 nerede tüm nesneyi nasıl silebilirim

Sadece ters yüklemle filtreleyin:

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

12
Bu cevap jQuery için en özlü ve deyimsel çözümü sağlar
Bryan

1
Eğer id = ile tüm öğeleri silmek istediğiniz durumda iyi bir şey ... ama tam diziyi arar ve uzun diziler için $ .grep kullanırken dikkatli olun. Bazen, öğenin belirli bir kimlikle dizinin içinde olup olmadığını kontrol etmeniz gerekir, o zaman başka bir yineleme yöntemi kullanmak daha iyidir;)
julianox

1
Bu, o nesneyi listeden kaldırmaz
Arun Sivan

1
@ArunSivan sliceda hiçbir şeyi kaldırmaz. Ne elde ettiğinden emin değilim. Belirli bir sorununuz varsa, yeni bir soru sormak isteyebilirsiniz .
Bergi

1
@Learnerdata.filter(e => !ids.includes(e.id))
Bergi

153

jquery kullanmıyorsanız bir çözüm:

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

2
Bu üst dizide findIndex()ve sonra yapmaktan daha mı iyi splice(index, 1)?
Alex

splice, kaynak diziyi değiştirir. Filtre ile seçim yapabilirsiniz.
velop

13
Bunu kullanarak bunu tek bir satıra azaltabilirsiniz: myArr = myArray.filter (obj => obj.id! == id);
DBrown

2
daha da özlüarr = arr.filter( obj => obj.id !== id);
Omar

86

Bunu basitleştirebilirsiniz ve burada jquery kullanmaya gerek yoktur.

var id = 88;

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

Sadece listeyi tekrarlayın, eşleşen kimliği bulun, birleştirin ve döngüden çıkmak için kırın


17
+1, ancak bunun yalnızca eşleşen ilk öğeyi sildiğini belirtmelisiniz.
Bergi

6
... Ve eşleşen her bir öğeyi silmeniz gerekiyorsa, ters sırayla döngü yapın i=data.length; i > 0; i--ve kullanmayın break.
Jeremy Belolo

3
i = data.lengthHerhangi kıracak data[i], bu gibi bir şey olmalıi=data.length -1 ; i > -1; i--
distante

31

ES6 / 2015'te findIndex ve dizi yayma işlecini kullanarak bunu yapmanın yeni bir yöntemi vardır:

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

Daha sonra şu şekilde yeniden kullanmak için bir işleve dönüştürebilirsiniz:

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;
}

Bu şekilde, bir yöntemi kullanarak öğeleri farklı anahtarlarla kaldırabilirsiniz (ve ölçütleri karşılayan bir nesne yoksa, orijinal diziyi döndürürsünüz):

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

Veya Array.prototype'inize koyabilirsiniz:

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;
};

Ve şu şekilde kullanın:

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

findIndex () gerçekten harika! 👍
danielcraigie

9

Kimliklerin benzersiz olduğunu ve splicehile yapması gereken tek bir öğeyi kaldırmanız gerekeceğini varsayarsak :

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);

Geri arama işlevinizdeki öğeler geriye doğru. Olmalı each(data,function(idx,ele). Ben bunu anlamaya israf 30 dakika boyunca size fatura edeceğim :)
CSharper

Hata. Bu durumda yapabileceğim en az şey cevabımı güncellemektir. 30 dakikalık boşa harcadığınız için gerçekten kötü hissediyorum.
James Hibbard

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

JQuery kullanıyorsanız, jQuery.grep kullanın :

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

ES5 Array.prototype.filter kullanma :

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

1
Noooooo! jQueryHaritayı filtre olarak kullanmayın .
Bergi

1
Katılıyorum! Grep ile çözümünüz jQuery ile doğru çözümdür.
nekman

4

Belki $.grep()fonksiyon arıyorsunuz :

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
});

3

siftbu ve benzeri işlemler için güçlü bir toplama filtresidir. Düğümdeki tarayıcıda veya sunucu tarafında istemci tarafında çalışır. 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);

Bu gibi filtreler destekler $in, $nin, $exists, $gte, $gt, $lte, $lt, $eq, $ne, $mod, $all, $and, $or, $nor, $not, $size, $type, ve $regex, ve rekabetin bu API uyumlu MongoDB toplama filtreleme birlikte olmak.


Neden upwotes yok? Bu şey düzgün bir şekilde yazılmışsa ve korkunç bir hata yoksa, son derece yararlı olmalıdır.
Max Yari

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

Bu hile yapmalı, jsfiddle


0

Katı eşitliği test ediyorsanız, nesne kimliğini bir tamsayıya zorladığınızdan emin olun:

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

gösteri


0

Alt çizgi js kullanıyorsanız, nesneyi anahtara göre kaldırmak kolaydır. http://underscorejs.org . Misal:

  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];
  });
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.