我有一个这样的数组:var y = [1,2,3];

我想从数组y中移除2。

如何使用jQuery从数组中删除一个特定的值?我尝试过pop(),但它总是删除最后一个元素。


当前回答

有一个简单的解决方案与剪接。根据W3School,拼接语法如下;

array.splice(index, howmany, item1, ....., itemX)

需要索引。指定在什么位置添加/删除项的整数。使用负值指定从数组末尾开始的位置

需要多少。要删除的项的数目。如果设置为0,则不会删除任何项

item1,……, itemX可选。要添加到数组中的新项

请记住,下面的js将从给定数组中弹出一个或多个匹配的项,否则不会删除数组的最后一项。

var x = [1,2,3,4,5,4,4,6,7];
var item = 4;
var startItemIndex = $.inArray(item, x);
var itemsFound = x.filter(function(elem){
                            return elem == item;
                          }).length;

Or

var itemsFound = $.grep(x, function (elem) {
                              return elem == item;
                           }).length;

所以期末题应该是这样的

x.splice( startItemIndex , itemsFound );

希望这能有所帮助。

其他回答

一个工作的JSFIDDLE

你可以这样做:

var y = [1, 2, 2, 3, 2]
var removeItem = 2;

y = jQuery.grep(y, function(value) {
  return value != removeItem;
});

结果:

[1, 3]

http://snipplr.com/view/14381/remove-item-from-array-with-jquery/

第二个获得最多好评的答案是OP想要的预期行为的一行jQuery方法,但他们在代码的末尾出错了,而且它有一个缺陷。如果要删除的项实际上不在数组中,则最后一项将被删除。

一些人已经注意到了这个问题,一些人已经提供了防止这种情况发生的循环方法。我提供了我所能找到的最短、最干净的方法,并在他们的答案下评论了根据这个方法修复代码的方法。

var x = [1, 2, "bye", 3, 4];
var y = [1, 2, 3, 4];
var removeItem = "bye";

// Removing an item that exists in array
x.splice( $.inArray(removeItem,x), $.inArray(removeItem,x) ); // This is the one-liner used

// Removing an item that DOESN'T exist in array
y.splice( $.inArray(removeItem,y), $.inArray(removeItem,y) ); // Same usage, different array

// OUTPUT -- both cases are expected to be [1,2,3,4]
alert(x + '\n' + y);

数组x将很容易地删除元素“bye”,而数组y将保持不变。

使用参数$. inarray (removeItem,array)作为第二个参数实际上最终是要拼接的长度。由于没有找到该项,因此计算结果为array.splice(-1,-1);,这将导致没有任何内容被拼接…所有这些都不需要为此写一个循环。

只是把Sarfraz的答案加上去,很惊讶没有人把它变成一个函数。

如果在数组中不止一次有相同的值,则使用.filter方法使用ddagsan的答案。

函数arrayremovevalue(数组,removeValue){ var newArray = jQuery。grep(数组,函数(值){返回值!= removeValue;}); 返回newArray; } var promoItems = [1,2,3,4]; promoItems = arrayremoveeval (promoItems, 3) console.log (promoItems); promoItems = arrayremoveeval (promoItems, 3);//不移除任何东西 console.log (promoItems); < script src = " https://cdnjs.cloudflare.com/ajax/libs/jquery/1.2.3/jquery.min.js " > < /脚本>

我将用pick_and_remove()函数扩展Array类,如下所示:

var ArrayInstanceExtensions = {
    pick_and_remove: function(index){
        var picked_element = this[index];
        this.splice(index,1);
        return picked_element;
    } 
};
$.extend(Array.prototype, ArrayInstanceExtensions);

虽然看起来有点啰嗦,但现在可以在任何需要的数组上调用pick_and_remove() !

用法:

array = [4,5,6]           //=> [4,5,6]
array.pick_and_remove(1); //=> 5
array;                    //=> [4,6]

你可以在《口袋妖怪》主题的动作中看到这一切。

//This prototype function allows you to remove even array from array
Array.prototype.remove = function(x) { 
    var i;
    for(i in this){
        if(this[i].toString() == x.toString()){
            this.splice(i,1)
        }
    }
}

使用实例

var arr = [1,2,[1,1], 'abc'];
arr.remove([1,1]);
console.log(arr) //[1, 2, 'abc']

var arr = [1,2,[1,1], 'abc'];
arr.remove(1);
console.log(arr) //[2, [1,1], 'abc']

var arr = [1,2,[1,1], 'abc'];
arr.remove('abc');
console.log(arr) //[1, 2, [1,1]]

要使用这个原型函数,您需要将其粘贴到代码中。 然后你可以将它应用到任何带有“点符号”的数组:

someArr.remove('elem1')