js数组复制

来源:互联网 发布:淘宝免费申请试用几次 编辑:程序博客网 时间:2024/06/05 14:56
文章出处:http://blog.sina.com.cn/s/blog_51baa1570100io8r.html
一、 错误实现
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()返回也是数组。

vararray1=newArray("1","2","3");
vararray2;
array2
=array1.slice(0);
array1.length
=0;
alert(array2);
//返回1、2、3

三、使用concat()

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

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

四、测试

<!DOCTYPE HTMLPUBLIC"-//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>ArrayTest</title>
<script type="text/javascript">
vararray1;
vararray2;

functionclone1(){
array1
=newArray("1","2","3");
array2
=array1;
array1.length
=0;
alert(array2);
}

functionclone2(){
array1
=newArray("1","2","3");
array2
=array1.slice(0);
array1.length
=0;
alert(array2);
}

functionclone3(){
array1
=newArray("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