深浅拷贝?

一、定义:

浅拷贝:只复制对象的第一层属性,若第一层属性是引用类型(如对象、数组),则复制其内存地址,修改拷贝后的嵌套对象会影响原对象。

深拷贝:递归复制对象的所有层级,生成完全独立的副本

二、浅拷贝实现

1.Object.assign()
javascript 复制代码
const obj = { a: 1, b: { c: 2 } }; 
const clone = Object.assign({}, obj); // 浅拷贝 
clone.b.c = 3; // 原对象的 b.c 也会变为 3 
console.log("obj: ", obj) 
console.log("clone: ", clone)
2.展开运算符
javascript 复制代码
const arr = [1, 2, 3]; 
const newArr = [...arr]; // 浅拷贝 
newArr[2] = 4; 
console.log("arr: ", arr) 
console.log("newArr: ", newArr)
javascript 复制代码
const arr = [1, 2, { a: 3 }]; 
const newArr = [...arr]; // 浅拷贝 
newArr[2].a = 4; // 原数组的 { a: 3 } 变为 { a: 4 } 
console.log("arr: ", arr) 
console.log("newArr: ", newArr)

3.数组方法:slice, concat

slice:

javascript 复制代码
const arr = [1, 2, { a: 3 }]; 
const newArr = arr.slice(); // 浅拷贝 
newArr[2].a = 4 
console.log("arr: ", arr) 
console.log("newArr: ", newArr)

concat:

javascript 复制代码
const arr = [1, 2, { a: 3 }]; 
const newArr = arr.concat(); // 浅拷贝 
newArr[2].a = 4 
console.log("arr: ", arr) 
console.log("newArr: ", newArr)

三、深拷贝

1.JSON 方法
javascript 复制代码
const obj = { a: 1, b: { c: 2 } }; 
const clone = JSON.parse(JSON.stringify(obj)); // 深拷贝 
clone.b.c = 4 
console.log("obj", obj) 
console.log("clone", clone)

2.第三方库

javascript 复制代码
// Lodash 
const _ = require('lodash'); 
const clone = _.cloneDeep(obj);
相关推荐
天赐细莲1 分钟前
(C++17) 未捕获异常 uncaught_exceptions
开发语言·c++
EndingCoder2 分钟前
React从基础入门到高级实战:React 核心技术 - 动画与过渡效果:提升 UI 交互体验
前端·javascript·react.js·ui·前端框架·交互
magic 2455 分钟前
Java——设计模式(Design Pattern)
java·开发语言·设计模式
Blue.ztl1 小时前
菜鸟之路Day33一一Mybatis入门
java·开发语言·mybatis
Logan Lie2 小时前
Go 语言范围循环变量重用问题与 VSCode 调试解决方法
开发语言·vscode·golang
Despacito0o2 小时前
C++面向对象编程实战:继承与派生全解析
开发语言·c++
weixin_472339463 小时前
前端安全直传MinIO方案
前端·安全·状态模式
清水白石0083 小时前
WebSockets 在实时通信中的应用与优化
开发语言·汇编·python·websockets
冷凝女子5 小时前
【QT】QString和QStringList去掉空格的方法总结
开发语言·qt
互联网搬砖老肖7 小时前
React的单向数据绑定
前端·javascript·react.js