深浅拷贝?

一、定义:

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

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

二、浅拷贝实现

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);
相关推荐
2401_873204651 分钟前
C++中的策略模式进阶
开发语言·c++·算法
xushichao19896 分钟前
C++中的职责链模式实战
开发语言·c++·算法
清风徐来QCQ13 分钟前
js中的模板字符串
开发语言·前端·javascript
成都渲染101云渲染666618 分钟前
Houdini+Blender高效渲染方案(高配算力+全渲染器兼容)
前端·系统架构
2301_8184190119 分钟前
C++中的协程编程
开发语言·c++·算法
add45a21 分钟前
C++中的工厂方法模式
开发语言·c++·算法
java1234_小锋22 分钟前
Java高频面试题:Spring-AOP通知和执行顺序?
java·开发语言·spring
番茄去哪了26 分钟前
Java基础面试题day02
java·开发语言·面向对象编程
xushichao198930 分钟前
C++中的工厂模式高级应用
开发语言·c++·算法
njsgcs30 分钟前
c# solidworks 折弯系数检查
开发语言·c#