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);这样写和方法二相比较会减少垃圾内存(尤其实在在使用频率非常高的情况下)。