前端开发

 首页 > 前端开发 > javascript > JS中如何复制数组一、 错误实现二、 使用slice()三、 使用concat()四、 测试

JS中如何复制数组一、 错误实现二、 使用slice()三、 使用concat()四、 测试

分享到:
【字体:
导读:
          一、 错误实现 var array1 = new Array(1,2,3); var array2; array2 = array1; array1.length = 0; alert(array2); //返回为空 这种做法是错的,因为javascript分原始类型与引用类型(与java、c#类似)。Array是引用类...

一、 错误实现

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 

四、 测试

 
 
 
 
Array Test 
 
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);
} 
 
 
 
 
 
 
 


分享到:
js克隆对象、数组的常用方法
Ext的两种克隆的方法: 可以克隆对象、数据等:var newJson = Ext.clone(json); 只能克隆数组:var newJson = Ext.Array.clone(json);   JQuery的方法: 深复制【可以迭代】:var newJson = jQuery.extend(true,{}, json); 浅复制【不能迭代】:var newJson = jQuery.extend({}, json); var newJson = $.map(json,function...
javascript框架cookies的js框架
初学ajax,昨天做项目的同时,写了一个操作cookies的js框架,比较符合jsp或者asp操作cookies的习惯(因为javascript里本身没有这样的对象,操作cookies等于操作字符串,所以比较麻烦)。源代码已经上传点击下载该文件,以下是框架接口说明: 对象:document.xCookie / xCookie (两个对象同等) 方法:         document...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……