10

誰かが私に配列から文字列要素を削除する方法を教えてもらえますか私はこれをグーグルで持っていますそして私が得るのはインデックス番号で削除することだけです

私の例:

 var myarray = ["xyz" , "abc" , "def"] ; 
 var removeMe = "abc" ; 

  myarray.remove(removeMe) ; 
  consle.log(myarray) ; 

これは私がコンソールから得るものです:

Uncaught TypeError: Object xyz,abc,def has no method 'remove' 

jsfiddle

4

4 に答える 4

19

jQueryを使っているので

myarray.splice($.inArray("abc", myarray), 1);

編集 項目が配列にない場合、この「ワンライナー」はエラーをスローする可能性があります。もう少し良いもの

var index = $.inArray("abc", myarray);
if (index>=0) myarray.splice(index, 1);
于 2012-05-29T20:08:26.837 に答える
8

https://stackoverflow.com/a/3955096/711129から:

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

自分で関数を作成する必要があります。配列をループしてそこから要素を削除するか、この関数でそれを行うことができます。いずれにせよ、これは標準の JS 機能ではありません。

于 2012-05-29T20:06:44.750 に答える
5

以下のようにしてみてください、

myarray.splice(myarray.indexOf(removeMe),1); 

indexOf をサポートしていないブラウザーの場合は、以下のスクリプト ( MDN から) を追加できます。

if (!Array.prototype.indexOf) {  
    Array.prototype.indexOf = function (searchElement /*, fromIndex */ ) {  
        "use strict";  
        if (this == null) {  
            throw new TypeError();  
        }  
        var t = Object(this);  
        var len = t.length >>> 0;  
        if (len === 0) {  
            return -1;  
        }  
        var n = 0;  
        if (arguments.length > 0) {  
            n = Number(arguments[1]);  
            if (n != n) { // shortcut for verifying if it's NaN  
                n = 0;  
            } else if (n != 0 && n != Infinity && n != -Infinity) {  
                n = (n > 0 || -1) * Math.floor(Math.abs(n));  
            }  
        }  
        if (n >= len) {  
            return -1;  
        }  
        var k = n >= 0 ? n : Math.max(len - Math.abs(n), 0);  
        for (; k < len; k++) {  
            if (k in t && t[k] === searchElement) {  
                return k;  
            }  
        }  
        return -1;  
    }  
}  
于 2012-05-29T20:08:05.073 に答える