JavaScript的深拷贝与浅拷贝
一句话来解释什么是深浅拷贝,B拷贝A,当修改A,B如果变化,就是浅拷贝,反之就是深拷贝。
基本原理:
1.递归函数
2.对象内的值都是简单数据类型时 直接进行赋值
3.当我们遇到数组和对象时,可以再次调用函数,利用递归去拷贝数组和对象内的每个值
4.先数组 后对象 因为数组也是对象
下面是一个实现深拷贝的函数:
1 function deepClone(obj) { 2 let objClone = Array.isArray(obj) ? [] : {}; 3 if (obj && typeof obj === "object") { 4 for (key in obj) { 5 if (obj.hasOwnProperty(key)) { 6 //判断ojb子元素是否为对象(复杂数据类型),如果是,递归复制 7 if (obj[key] && typeof obj[key] === "object") { 8 objClone[key] = deepClone(obj[key]); 9 } else { 10 //如果不是,简单复制(基本数据类型) 11 objClone[key] = obj[key]; 12 } 13 } 14 } 15 } 16 return objClone; 17 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· Qt个人项目总结 —— MySQL数据库查询与断言