JavaScript数组及非数组对象的深浅克隆详解原理

作者:daixiangcn 时间:2024-04-19 09:52:51 

什么是浅克隆、深克隆

浅克隆:直接将存储在栈中的值赋值给对应变量,如果是基本数据类型,则直接赋值对应的值,如果是引用类型,则赋值的是地址。
深克隆:将数据赋值给对应的变量,从而产生一个与源数据不相干的新数据(数据地址已变化)。即对象各个层级的属性。
JavaScript中基本数据类型使用符号“=”可以进行克隆,引用数据类型使用符号“=”只是改变了变量的指向,并没有进行真正的克隆操作。

1.对数组进行克隆

1.1 浅克隆

使用for循环进行浅克隆。


var arr1 = ['demo', 1, 2];
var arr2 = [];
// 数组的浅克隆
for (var i = 0; i < arr1.length; i++) {
   arr2[i] = arr1[i];
}
console.log(arr2);
console.log(arr1 == arr2);

输出结果:

Array(3)0: "demo"1: 12: 2length: 3[[Prototype]]: Array(0)
false

1.2 深克隆

使用递归进行深克隆。


function deepClone(o) {
var result = [];
for (var i = 0; i < o.length; i++) {
result.push(deepClone(o[i]));
}
return result;
}

2.对非数组对象进行克隆

2.1 浅克隆

使用for循环进行浅克隆。


var obj1 = { a: 1, b: 2, c: 3, d: [4, 5, { e: 'demo' }] };
var obj2 = {};
// 对象的浅克隆
for (var i in obj1) {
   obj2[i] = obj1[i];
}
console.log(obj2);
console.log(obj1 == obj2);

输出结果:

{a: 1, b: 2, c: 3, d: Array(3)}
false

2.2 深克隆

使用递归进行深克隆。


function deepClone(o) {
var result = {};
for (var i in o) {
result[i] = deepClone(o[i]);
}
return result;
}

3.整合深克隆函数


var obj1 = { a: 1, b: 2, c: 3, d: [4, 5, { e: 'demo' }] };
var arr1 = ['demo', 1, 2];
// 深克隆
function deepClone(o) {
   if (Array.isArray(o)) {
       // 是数组
       var result = [];
       for (var i = 0; i < o.length; i++) {
           result.push(deepClone(o[i]));
       }
   } else if (typeof o == 'object') {
       // 非数组,是对象
       var result = {};
       for (var i in o) {
           result[i] = deepClone(o[i]);
       }
   } else {
       // 基本类型值
       var result = o;
   }
   return result;
}
console.log(deepClone(arr1));
console.log(deepClone(obj1));

来源:https://blog.csdn.net/yuanxiang01/article/details/120759457

标签:JavaScript,数组,深浅克隆
0
投稿

猜你喜欢

  • asp中用insert into语句向数据库插入记录(添加信息)的方法

    2011-02-05 10:46:00
  • Python最长公共子串算法实例

    2022-08-11 01:29:57
  • 详解Django-auth-ldap 配置方法

    2023-05-16 14:50:17
  • python线程池的实现实例

    2022-11-21 11:24:27
  • python实现登录与注册系统

    2022-04-26 02:32:38
  • python字符串不可变数据类型

    2021-04-14 23:07:09
  • js图片水平翻转后垂直翻反转的特效代码

    2009-03-06 15:33:00
  • python实现计算资源图标crc值的方法

    2022-07-02 17:57:56
  • python实现读取大文件并逐行写入另外一个文件

    2021-02-03 21:10:45
  • python实现远程通过网络邮件控制计算机重启或关机

    2022-04-16 01:05:27
  • Python *args和**kwargs用法实例解析

    2023-01-16 18:30:55
  • css清除浮动的最优方法

    2008-04-25 22:33:00
  • Python安装selenium包详细过程

    2023-04-12 00:05:31
  • Python可变集合和不可变集合的构造方法大全

    2021-10-23 12:39:04
  • Python+Opencv实现计算闭合区域面积

    2023-03-17 03:02:44
  • mysql中max_allowed_packet参数的配置方法(避免大数据写入或者更新失败)

    2024-01-17 06:06:08
  • 数据库之:Mysql数据库服务器安装与配置

    2010-08-31 14:11:00
  • python实现录制全屏和选择区域录屏功能

    2022-06-18 01:06:33
  • VBScript中清除数组元素Erase语句

    2008-06-27 13:05:00
  • 简单聊聊Golang中defer预计算参数

    2023-07-22 03:55:09
  • asp之家 网络编程 m.aspxhome.com