JavaScript深浅克隆是什么意思,如何对数组实现
Admin 2022-06-27 群英技术资讯 476 次浏览
浅克隆:直接将存储在栈中的值赋值给对应变量,如果是基本数据类型,则直接赋值对应的值,如果是引用类型,则赋值的是地址。
深克隆:将数据赋值给对应的变量,从而产生一个与源数据不相干的新数据(数据地址已变化)。即对象各个层级的属性。
JavaScript中基本数据类型使用符号“=”可以进行克隆,引用数据类型使用符号“=”只是改变了变量的指向,并没有进行真正的克隆操作。
使用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
使用递归进行深克隆。
function deepClone(o) { var result = []; for (var i = 0; i < o.length; i++) { result.push(deepClone(o[i])); } return result; }
使用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
使用递归进行深克隆。
function deepClone(o) { var result = {}; for (var i in o) { result[i] = deepClone(o[i]); } return result; }
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));
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
主要思路在需要拖拽宽度的区域设置一个div,高度设为 100%,宽度尽量窄一些(也不要太窄,3~6px左右)在此div上绑定当“鼠标按下”时,触发document绑定“鼠标移动”方法和鼠标抬起方法通过鼠标移动方法不断获取当前鼠标位置,设置需要变化大小div的宽高。鼠标抬起时取消鼠标移动方法和鼠标抬起方法的绑定。temp
删除,可以删除任何数量的项目。只需指定两个参数。要删除的第一项的位置和要删除的项目数。插入,指定位置插入任意数量的项目。更换,可以将任意数量的项插入指定位置,同时删除任意数量的项。
今天给大家分享的是关于vue修饰符及用法的内容,本文提到的vue修饰符小编觉得比较实用,也是面试常考的vue修饰符,因此分享给大家做个参考,接下来跟随小编一起看看吧。
这篇文章主要为大家详细介绍了小程序实现列表倒计时功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
nodejs运行项目出现Error: Cannot find module ws错误一般就是缺少了这个为“ws”的module模块,错误信息大致如下: Error: Cannot find module ws Require stack: - C:\Users\Administrator\Desktop\pcm-player-master\example\server\server.js [90m at Fu
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008