从数组中删除元素的最佳方法:javascript / jquery

时间:2012-09-12 09:57:20

标签: javascript jquery

我找到了两种方法。哪一个更好?还有比这两个更好的方法吗?

 myArray.splice($.inArray(id, myArray),1);

myArray.splice(myArray.indexOf(id),1);

3 个答案:

答案 0 :(得分:2)

这两个选项都不安全,因为如果找不到id,两者都会删除数组中的最后一个元素。

无论您使用$.inArray()还是.indexOf(),如果-1不在数组中,并且您通过id,您将获得-1的返回} .splice() method它将删除数组中的最后一项。

所以你应该说:

var index = $.inArray(id, myArray); // or myArray.indexOf(id)
if (index > -1) myArray.splice(index, 1);

显然,如果需要,您可以将上述内容封装在您自己的函数中。

至于$.inArray().indexOf()中哪一个更好,这取决于您是否关心支持不支持.indexOf()的旧版浏览器(主要是IE8及更低版本)。如果你的代码在公共网站上,你应该关心,因为很多人仍然使用IE8和IE7。如果您已经在使用jQuery,那么您可以坚持使用$.inArray(),否则请使用.indexOf() shim at MDN

答案 1 :(得分:0)

清空整个阵列:

while (myArray.length) {
  var element = myArray.shift();
  element = null; // free memory
}
myArray = [];

或删除单个元素:

var element = myArray.splice(id,1);
element = null; // free memory

答案 2 :(得分:0)

您也可以使用以下方法从数组中删除元素。

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

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

OR

var arr = ["jQuery","JavaScript","HTML","Ajax","Css"];
var itemtoRemove = "HTML";
arr.splice($.inArray(itemtoRemove, arr),1);

以上两种方式都是最好的。

注意: IE< 9不支持数组上的.indexOf()。如果你想确保你的代码在IE中运行。