JS中复制数组

来源:互联网 发布:网络被限制怎么解除 编辑:程序博客网 时间:2024/06/05 19:04
一、 错误实现
var array1 = new Array("1","2","3"); 
var array2; 
array2 
= array1; 
array1.length 
= 0
alert(array2); 
//返回为空

这种做法是错的,因为javascript分原始类型与引用类型(与java、c#类似)。Array是引用类

型。array2得到的是引用,所以对array1的修改会影响到array2。

二、 使用slice()

可使用slice()进行复制,因为slice()返回也是数组。

var array1 = new Array("1","2","3"); 
var array2; 
array2 
= array1.slice(0); 
array1.length 
= 0
alert(array2); 
//返回1、2、3  


定义和用法

slice() 方法可从已有的数组中返回选定的元素。

语法

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

返回值

返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。

说明

请注意,该方法并不会修改数组,而是返回一个子数组。如果想删除数组中的一段元素,应该使用方法 Array.splice()。


三、 使用concat()

注意concat()返回的并不是调用函数的Array,而是一个新的Array,所以可以利用这一点进行复制。

var array1 = new Array("1","2","3"); 
var array2; 
array2 
= array1.concat(); 
array1.length 
= 0
alert(array2); 
//返回1、2、3 

四、 测试

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title>Array Test</title> 
<script type="text/javascript"> 
var array1; 
var array2; 

function clone1() {
array1 
= new Array("1","2","3");
array2 
= array1; 
array1.length 
= 0
alert(array2); 


function clone2() 
array1 
= new Array("1","2","3");
array2 
= array1.slice(0); 
array1.length 
= 0
alert(array2);


function clone3() 
array1 
= new Array("1","2","3");
array2 
= array1.concat(); 
array1.length 
= 0
alert(array2);


</script> 

</head> 
<body> 
<input type="button" value="clone1" onclick="clone1()" /><br /> 
<input type="button" value="clone2" onclick="clone2()" /><br /> 
<input type="button" value="clone3" onclick="clone3()" /><br /> 
</body> 
</html>


0 0