方法一:



定义和用法

splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。

注释:该方法会改变原始数组。

语法



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



参数

描述

index

必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。

howmany

必需。要删除的项目数量。如果设置为 0,则不会删除项目。

item1, ..., itemX

可选。向数组添加的新项目。

返回值

类型

描述

Array

包含被删除项目的新数组,如果有的话。

说明

splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。

如果从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。


方法二:


//arr:需要删除元素的数组 index:要删除元素的索引
function delElByIndex(arr,index){
   var sliced = arr.slice(index+1);//将需要删除元素后续的元素截取出来保存
   arr.length=index;//将需要删除的元素以及后续的所有元素删除
   console.log(sliced,arr);//sliced=>[4, 5] arr=>[0, 1, 2] 注意:这个时候参数index所对应的元素已经删除了
   //arr.push(sliced);
   arr.push.apply(arr,sliced);//将sliced中的元素复制回原数组arr中
   console.log(sliced,arr);//sliced=>[4, 5] arr=>[0, 1, 2, 4, 5]
};
delElByIndex([0,1,2,3,4,5],3);


然而,slice方法会返回一个新的数组对象(数组中的元素是原数组中删掉的部分),并且会通过arr.push.apply方法将元素重新复制回原数组,但是在此操作之后,该数组就成为了一片内存垃圾。由于这是我们引擎中的垃圾产生的热点代码(使用频率非常很高),因此我们利用了迭代的方式重写了上述代码(见 方法二)。


方法三:


function delElByIndex(arr,index){
   for(var i=index,len=arr.length-1;i<len;i++)
      arr[i]=arr[i+1];
   arr.length = len;
   console.log(arr);//=>[0, 1, 2, 4, 5] 
};
delElByIndex([0,1,2,3,4,5],3);

这样写和方法二相比较会减少垃圾内存(尤其实在在使用频率非常高的情况下)。



总结:我们在开发中经常使用和常见的是利用方法一来实现数组对象根据索引(index)删除元素的功能。方法二和方法三是自定义的一个函数来实现此功能,这两方法的由来见此文章 。