자바 스크립트는 키 값을 기준으로 배열에서 객체를 찾고 제거합니다.


139

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!"}
]

slice함수와 작은 for루프를 사용 하는 것은 어떻습니까?
Ahmed Hamdy

1
그러나, 내가이 질문을 쓴 이유는 내가 붙어 있기 때문입니다.) 스 니펫?
Tom

이 게시물을 확인하십시오 stackoverflow.com/questions/10827894/…
Ahmed Hamdy

제목과 질문 텍스트가 충돌하는 것 같습니다 ... 완전히 다른 두 가지 접근 방식을 제안합니다. A. 대 배열에서 제거 항목을 B.는 새로운 필터 배열을 만들 수 있습니다.
canon

답변:


155

id의 배열을 grep 할 수는 있지만 id == 88 인 전체 객체를 어떻게 삭제할 수 있습니까?

반대 술어로 간단히 필터링하십시오.

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

12
이 답변은 jQuery를위한 가장 간결하고 관용적 인 솔루션을 제공합니다
Bryan

1
id = something으로 모든 항목을 삭제하려는 경우 괜찮습니다 ...하지만 $ .grep을 사용하면 전체 배열을 검색하므로 긴 배열의 경우 효율적이지 않습니다. 때로는 주어진 ID로 요소가 배열 내에 존재하는지 확인 해야하는 경우 다른 반복 방법을 사용하는 것이 좋습니다.)
julianox

1
이것은 목록에서 해당 개체를 제거하지 않습니다
Arun Sivan

1
@ArunSivan slice은 아무것도 제거하지 않습니다. 무엇을 받고 있는지 잘 모르겠습니다. 특정 문제가있는 경우 새로운 질문 을 할 수 있습니다 .
Bergi

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

153

jquery를 사용하지 않는 경우 해결책은 다음과 같습니다.

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

2
이 것보다 더 나은 findIndex()다음 splice(index, 1)상위 배열에?
Alex

splice는 원래 배열을 변경합니다. 필터를 사용하면 선택할 수 있습니다.
velop

13
다음을 사용하여이를 한 줄로 줄일 수 있습니다. myArr = myArray.filter (obj => obj.id! == id);
DBrown

2
더 간결한arr = arr.filter( obj => obj.id !== id);
Omar

86

이것을 단순화 할 수 있으며 여기서는 jquery를 사용할 필요가 없습니다.

var id = 88;

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

목록을 반복하고 일치하는 ID, 스플 라이스를 찾은 다음 중단하여 루프를 종료하십시오.


17
+1이지만 일치하는 첫 번째 항목 만 삭제한다고 언급해야합니다.
베르 기

6
... 그리고 일치하는 각 항목을 삭제해야하는 경우에는 반대 순서로 반복하고 i=data.length; i > 0; i--사용하지 마십시오 break.
제레미 벨로로

3
i = data.length어떤 data[i]것을 i=data.length -1 ; i > -1; i--
깨뜨릴

31

findIndex 및 array spread 연산자를 사용하여 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!");

findIndex () 정말 좋습니다! 👍
danielcraigie

9

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

콜백 함수의 요소는 거꾸로 있습니다. 이어야합니다 each(data,function(idx,ele). 나는 밖으로 :)내는 낭비 30 분 나는 나중에 당신을 청구합니다
CSharper

죄송합니다. 이 경우 내가 할 수있는 최소한의 답변을 업데이트하는 것입니다. 당신의 인생 30 분 낭비에 대해 정말 기분이 좋지 않습니다.
제임스 히 바드

5
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" }]

1
안돼! jQuery맵을 필터로 사용하지 마십시오 .
Bergi

1
동의하다! grep을 사용하는 솔루션은 jQuery를 사용하는 올바른 솔루션입니다.
nekman

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

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, $eq, $ne, $mod, $all, $and, $or, $nor, $not, $size, $type,와 $regex, 그리고 최선의 노력을 기울이고은 API 호환 MongoDB를 수집 필터링 할 수 있습니다.


왜 upwotes가 없습니까? 이 글이 제대로 작성되었고 끔찍한 버그가 없다면 매우 유용 할 것입니다.
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;
}

이 트릭을해야합니다, jsfiddle


0

엄격한 동등성을 테스트하는 경우 객체 ID를 정수로 강제 변환하십시오.

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

데모


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];
  });
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.