数组的拷贝

  > 数组的深拷贝,两层
var arr = [[1,2,3],[4,5,6],[7,8,9]];

var arr2 = [];
循环第一层数组
for(var i=0,len=arr.length;i<len;i++){
  循环第二层数组
for(var k=0,lens=arr[i].length;k<lens;k++){
    把每一个数组的内容添加到数组2中
arr2.push(arr[i][k]);
}
} console.log(arr2); //[1, 2, 3, 4, 5, 6, 7, 8, 9] console.log(arr===arr2); //false
  > 数组的浅拷贝,一层
var arr = [1,2,3,4,5,6,7,8];
var arr2 = [];
for(var i=0,len=arr.length;i<len;i++){
arr2.push(arr[i]);
} console.log(arr2);
console.log(arr===arr2);
  > 数组的深拷贝,三层
    var arr = [[1,2,3,[4,5]],[[6,7,8,9]],10,11];
var arr2 = [];
// 第一层循环
for(var i=0,len=arr.length;i<len;i++){

     // 如果第一层不是数组则直接拷贝到数组2中
     if(typeof arr[i]!=="object"){
       arr2.push(arr[i]);
     }

// 第二层
for(var k=0,len1=arr[i].length;k<len1;k++){
// 判断第二层是否是数组,这里简单的判断力一下是不是对象,没有做处理。
if(typeof arr[i][k]==="object"){
// 如果是数组,继续循环此数组。
for(var j=0,len2=arr[i][k].length;j<len2;j++){
arr2.push(arr[i][k][j]);
}
}else{
// 不是数组就按照正常情况执行。
arr2.push(arr[i][k]);
} }
} console.log(arr2); //[1, 2, 3, 4, 5, 6, 7, 8, 9,10,11]
console.log(arr===arr2); //false
  > 数组的深拷贝,无限层,正则版 1.0
    var arr = [[1,2,3,[4,5]],[[6,7,8,9]],10,11,12,13,[14,[15,16,17,[18,[19,[20]]]]]];
var arr2 = [];
// 先把数组转换成字符串,然后将字符串里面的[]删除
var str = arr.toString().replace(/\[|\]/,"");
console.log(str); //1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20 // 将字符串转换成数组。
arr2 = str.split(",");
console.log(arr2); //["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20"]
console.log(arr===arr2); //false

  // 这样做的话简单了不少,而且扩展性比较强,但是现在出现了个bug,就是我们原本数组里面的是数字,现在变成了字符串,下面我们来解决一下这个问题。

  > 数组的深拷贝,无限层,正则版 2.0
    var arr = [[1,2,3,[4,5]],[[6,7,8,9]],10,11,12,13,[14,[15,16,17,[18,[19,[20]]]]],"a"];
var arr2 = [];
// 先把数组转换成字符串,然后将字符串里面的[]删除
var str = arr.toString().replace(/\[|\]/,"");
console.log(str); //1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20 // 将字符串转换成数组。
arr2 = str.split(",");
for(var i=0,len=arr2.length;i<len;i++){
// 判断是否可以转换成数字,如果可以则转换,否则不转换。
arr2[i] = parseFloat(arr2[i])||arr2[i]; }
console.log(arr2); //[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, "a"]
console.log(arr===arr2); //false

  虽然这里解决了上面的问题,但实际上还是有些问题的,就是如果arr1里面的数字原本就是字符串那么这个就有问题了,因为这个我们设置的是只要它可以转换成数字都将被转换。如果要解决这个问题的话,我们在将数组转换成字符串之前就要进行判断里面的内容是数字还是字符串,但是如果这样的话,我们用正则的方式将会变的非常麻烦,因为技术有限,只能解决到这里,如果你有好的方法,还请告知一下。

对象的克隆和数组的克隆差不多,这里就不再说了,另外以前还写了一篇关于克隆方面的文章,有兴趣的话可以参考一下。

JS基础回顾,小练习(克隆对象,数组)

JS中实现数组和对象的深拷贝和浅拷贝的更多相关文章

  1. JS中遍历数组、对象的方式

    1.标准的for循环遍历数组 //不打印自定义属性和继承属性 var array = [1,2,3]; for (var i = 0; i < array.length; i++) { cons ...

  2. js 中数组或者对象的深拷贝和浅拷贝

    浅拷贝 : 就是两个js 对象指向同一块内存地址,所以当obj1 ,obj2指向obj3的时候,一旦其中一个改变,其他的便会改变! 深拷贝:就是重新复制一块内存,这样就不会互相影响. 有些时候我们定义 ...

  3. JS 数组以及对象的深拷贝总结

    javascript 数组以及对象的深拷贝(复制数组或复制对象)的方法 前言 在js中,数组和对象的复制如果使用=号来进行复制,那只是浅拷贝.如下图演示:  如上,arr的修改,会影响arr2的值,这 ...

  4. javascript 数组以及对象的深拷贝(复制数组或复制对象)的方法

    前言 for,slice(0),concact() 在js中,数组和对象的复制如果使用=号来进行复制,那只是浅拷贝.如下图演示:  如上,arr的修改,会影响arr2的值,这显然在绝大多数情况下,并不 ...

  5. JS 数组、对象的深拷贝

    博客地址:https://ainyi.com/72 JavaScript 程序中,对于简单的数字.字符串可以通过 = 赋值拷贝 但是对于数组.对象.对象数组的拷贝,就有浅拷贝和深拷贝之分 浅拷贝就是当 ...

  6. JS中,JSON 和 对象互转,数组和字符串的转换?

    JSON 与 J对象转化 要实现从对象转换为 JSON 字符串,使用 JSON.stringify() 方法: 如下: var json = JSON.stringify({a: 'Hello', b ...

  7. JS中的数组复制问题

    JS中的数组复制问题 前言 首先提到复制,也就是拷贝问题,就必须要明确浅拷贝和深拷贝. 浅拷贝:B由A复制而来,改变B的内容,A也改变 深拷贝:B由A复制而来,改变B的内容,A的内容不会改变 总的来说 ...

  8. JS中Array数组的三大属性用法

    原文:JS中Array数组的三大属性用法 Array数组主要有3大属性,它们分别是length属性.prototype属性和constructor属性. JS操作Array数组的方法及属性 本文总结了 ...

  9. JS中的内置对象简介与简单的属性方法

    JS中的数组: 1.数组的概念: 数组是在内存中连续存储的多个有序元素的结构,元素的顺序称为下标,通过下标查找对应元素 2.数组的声明: ①通过字面量声明var arr1 = [,,,,] JS中同一 ...

随机推荐

  1. #知识#室内设计原理ing

    室内设计原理 第一章 室内设计的含义和基本观点 人的一生,绝大部分时间是在室内度过的,因此,人们设计创造的室内环境,必然会直接关系到室内生活.生产活动的质量,关系到人们的安全.健康.效率.舒适等等.室 ...

  2. javascript练习-方法借用

    方法借用其实也可以叫做多重继承 var generic = { //返回一个字符串,这个字符串包含构造函数的名字(如果构造函数包含名字) //这个以及所有非继承来的,非函数属性的名字和值 toStri ...

  3. 简单BigDecimal运算精度

    项目中遇到了数值运算,如网上所写的,一般有这几个方法: /** * 提供精确的加法运算. * @param v1 被加数 * @param v2 加数 * @return 两个参数的和 */ publ ...

  4. java和android及IOS对接RSA加密经验

    1.网上找的java生成RSA密钥对的例子,产生的字附串实际上是hax后和密钥串 你可以将他们当成静态字附串存在java代码里 2.android和java可以代码复用,IOS对接比较麻烦 3.IOS ...

  5. 利用html5 canvas实现纯前端上传图片的裁剪

    今天跟大家分享一个前端裁剪图片的方法.许多网站都有设置用户头像的功能,用户可以选择一张本地的图片,然后用网站的裁剪工具进行裁剪,然后设置大小,位置合适的头像.当然,网上也有一些用js写的诸如此类裁剪的 ...

  6. 2.使用JDK开发webService

    使用jdk开发webService需要注意:jdk版本必须1.6以及1.6以上! 以下webService的组成部分: server端和client端,通过服务器端(server)webService ...

  7. MYSQL删除表的记录后如何使ID从1开始

    MYSQL删除表的记录后如何使ID从1开始 MYSQL删除表的记录后如何使ID从1开始 http://hi.baidu.com/289766516/blog/item/a3f85500556e2c09 ...

  8. ubuntu共享文件配置

    目标:实现windows和linux混合组成的操作 系统中可以共享文件,并可以通过机器名互相访问 安装文件共享服务 0.更改本机主机名,修改 /etc/hostname文件和/etc/hosts文件中 ...

  9. android项目中values中几个文件的作用

    最近反编译了几个Android软件,发现一些以前未用到的资源文件:ids.xml——为应用的相关资源提供唯一的资源id.id是为了获得xml中的对象而需要的参数,也就是Object = findVie ...

  10. 【推荐】【给中高级开发者】构建高性能ASP.NET应用的几点建议

    本篇目录 早期阶段就要对应用进行负载测试 使用高性能类库 你的应用是CPU密集还是IO密集的 使用基于Task的异步模型,但要慎重 分发缓存和会话(session)状态 创建Web Gardens 巧 ...