您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery | 小程序 |

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

51自学网 2022-02-21 13:39:29
  javascript

什么是浅克隆、深克隆

浅克隆:直接将存储在栈中的值赋值给对应变量,如果是基本数据类型,则直接赋值对应的值,如果是引用类型,则赋值的是地址。
深克隆:将数据赋值给对应的变量,从而产生一个与源数据不相干的新数据(数据地址已变化)。即对象各个层级的属性。
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));

到此这篇关于JavaScript数组及非数组对象的深浅克隆详解原理的文章就介绍到这了,更多相关JavaScript 数组内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


下载地址:
浅谈VUE uni-app 模板语法
浅谈VUE uni-app 基础组件
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。