代码改变世界

Javascript中Array的slice 方法与 splice 方法理解

2012-07-18 11:46  VVG  阅读(319)  评论(0编辑  收藏  举报

slice定义:返回arrayObject数组中的start到end(但不包含end)的一个新数组,不影响原数组的值;

arrayObject.slice(start,end)

 

参数详解:

参数描述
start 必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end 可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。

 

实例:

var arr1 = [0,1,2,3,4,5,6,7,8,9]; 
var arr2 = arr1.slice(1,8); 
var arr3= arr1.slice(2);
console.log(arr1); // [0,1,2,3,4,5,6,7,8,9]
console.log(arr2); // [1, 2, 3, 4, 5, 6, 7]
console.log(arr3); // [2, 3, 4, 5, 6, 7, 8, 9]

 

 splice定义:用于插入、删除或替换数组的元素。影响原数组,返回被删除的数组成的数组,语法如下:

arrayObject.splice(index,howmany,element1,.....,elementX)

参数详解:

参数描述
index

必需。规定从何处添加/删除元素。

该参数是开始插入和(或)删除的数组元素的下标,必须是数字。

howmany

必需。规定应该删除多少元素。必须是数字,但可以是 "0"。

如果未规定此参数,则删除从 index 开始到原数组结尾的所有元素。

element1 可选。规定要添加到数组的新元素。从 index 所指的下标处开始插入。
elementX 可选。可向数组添加若干元素。

 

实列:

var arr1 = [0,1,2,3,4,5,6,7,8,9];  
var arr2 = arr1.splice(3,3,'add','new','number'); 
console.log(arr1); // [0, 1, 2, "add", "new", "number", 6, 7, 8, 9]
console.log(arr2); // [3, 4, 5]

-------------------------------------------------------------------------------

var arr1 = [0,1,2,3,4,5,6,7,8,9];  
var arr2 = arr1.splice(3); 
console.log(arr1); // [0, 1, 2]
console.log(arr2); // [3, 4, 5, 6, 7, 8, 9]