IT/Javascript
Javascript - 배열(Array)에서 value 값으로 삭제하기
Normal_One
2017. 8. 12. 15:19
일을 하고 있던 와중에 배열에서 value 값을 찾아서 삭제해야 하는 경우가 생겼습니다. 그래서 열심히 구글링을 해보니 아래와 같은 방법이 있었습니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | Array.prototype.remove = function() { var what, a = arguments, L = a.length, ax; while (L && this.length) { what = a[--L]; while ((ax = this.indexOf(what)) !== -1) { this.splice(ax, 1); } } return this; }; var ary = ['three', 'seven', 'eleven']; ary.remove('seven'); /* 배열 자체에 프로토 타입으로 선언하여 생성 */ function removeA(arr) { var what, a = arguments, L = a.length, ax; while (L > 1 && arr.length) { what = a[--L]; while ((ax= arr.indexOf(what)) !== -1) { arr.splice(ax, 1); } } return arr; } var ary = ['three', 'seven', 'eleven']; removeA(ary, 'seven'); /* function 으로 만들어준 형태 */ | cs |
이렇게 선언해주고 배열에서 삭제를 해보려 했더니 잘 동작하지 않았습니다. F12를 눌러서 console 창을 보니 뻘건 에러가 나고 있었는데, 뭐가 원인인지 찾아보니 IE에서는 indexOf가 작동하지 않음을 알게 되었습니다. 그래서 다시 구글링을 해보니 아래와 같은 내용을 찾을 수 있었습니다.
1 2 3 4 5 6 7 8 9 10 11 | if(!Array.prototype.indexOf) { Array.prototype.indexOf = function(what, i) { i = i || 0; var L = this.length; while (i < L) { if(this[i] === what) return i; ++i; } return -1; }; } | cs |
바로 indexOf를 prototype으로 만들어주는 코드입니다. 이렇게 해서 배열에서 value값을 찾아 삭제하여 일이 끝난 줄 알았는데....
이렇게 하니 생긴 문제가, 다른 곳에서 배열을 잃어 들이다가 이 prototype들을 value로 판단하여 for문 안에서 이 구문을 값으로 하여 로직이 도는 경우가 있었습니다. 그래서 애써 찾은 코드들을 지우고 다시 찾아보기 시작했습니다. 해답은 역시 jQuery에 있었습니다. jQuery에서 제공해주는 API 중 하나인 grep을 사용하니 손쉽게 해결 되었습니다.
위 사진은 jQuery 홈페이지에서 캡쳐한 사진입니다. grep은 위와 같이 사용하면 되는데 여기서 n은 value를 뜻하고 i는 index를 의미합니다. return은 다시 돌려줄 배열을 의미합니다. 따라서, 예를 들어 제가 [0, 1, 2]라는 배열에서 지우고 싶은 값이 '1' 이라면
1 2 3 | $.grep( [ 0, 1, 2 ], function( n, i ) { return n != 1; }, true ); | cs |
위와 같이 해주면 됩니다. 역시 jQuery만큼 편한게 없네요. 사실 간단히 생각하면 배열 for문 돌린 후 해당 값이 아닌 값들만 다시 배열에 넣어주기만 하면 되는 일이긴 한데, 어째 jQuery API를 보니 그런 생각이 나는걸 보니 머리가 굳긴 했나 봅니다. 아무튼, 다들 유용하게 쓰시길 바랍니다.