Javascript 复制数组实现代码

 更新时间:2009年11月26日 18:44:30   作者:  
Javascript 复制数组实现代码,需要的朋友可以参考下。
一、 错误实现
不少人可能直接就用等号进行赋值了:
复制代码 代码如下:

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

三、 使用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>

在IE8及FF3.0下均通过测试

相关文章

  • 通过一段代码简单说js中的this的使用

    通过一段代码简单说js中的this的使用

    本文通过一段代码与大家简单说说js中this的使用及相关问题,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • 删除Javascript Object中间的key

    删除Javascript Object中间的key

    这篇文章介绍了删除Javascript Object中间的key的方法,然后主要详谈了delete的用法,非常的详尽,给小伙伴们参考下
    2014-11-11
  • 关于JS管理作用域的问题

    关于JS管理作用域的问题

    本篇文章中,小编为大家介绍关于JS管理作用域的问题,有需要的朋友可以关注一下
    2013-04-04
  • JS跨域问题详解

    JS跨域问题详解

    本文结合实际,分两种情况讨论跨域技术:首先讨论不同子域的跨域技术,然后讨论完全不同域的跨域技术。有需要的小伙伴可要看仔细了。
    2014-11-11
  • JavaScript中的Math.E属性使用详解

    JavaScript中的Math.E属性使用详解

    这篇文章主要介绍了JavaScript中的Math.E属性使用详解,是JS入门学习中的基础知识,需要的朋友可以参考下
    2015-06-06
  • JS中处理时间之setUTCMinutes()方法的使用

    JS中处理时间之setUTCMinutes()方法的使用

    这篇文章主要介绍了JavaScript中处理时间之setUTCMinutes()方法的使用,是JavaScript入门学习中的基础知识,需要的朋友可以参考下
    2015-06-06
  • javaScript面向对象继承方法经典实现

    javaScript面向对象继承方法经典实现

    很多人都说JavaScript不能算是面向对象的变成语言。但是JavaScript的类型非常松散,也没有编译器,但是我们可以模仿着其他语言实现面向对象的方式来实现JavaScript的面向编程
    2013-08-08
  • 辨析JavaScript中的Undefined类型与null类型

    辨析JavaScript中的Undefined类型与null类型

    Undefined与null都是js中的基本数据类型,然而正如它们的名字那样,未初始化和空并不相同,下面我们就来详细辨析JavaScript中的Undefined类型与null类型:
    2016-05-05
  • 浅析JavaScript中的delete运算符

    浅析JavaScript中的delete运算符

    这篇文章主要是对JavaScript中的delete运算符进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • Javascript学习笔记之函数篇(四):arguments 对象

    Javascript学习笔记之函数篇(四):arguments 对象

    JavaScript中arguments函数对象是该对象代表正在执行的函数和调用它的函数的参数。JavaScript 函数中 arguments 为特殊对象,无需明确指出参数名,就能访问它们。
    2014-11-11

最新评论