赞
踩
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);
这样写和方法二相比较会减少垃圾内存(尤其实在在使用频率非常高的情况下)。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。