各位观众老爷,大家好!我是你们的老朋友,今天咱们来聊聊JS里深拷贝的官方“嫡传弟子”——structuredClone()。 过去,一提到深拷贝,大家脑海里浮现的可能是JSON序列化/反序列化、递归函数,或者各种第三方库。这些方法各有优缺点,但总感觉不够“正统”。现在好了,ES2022给我们带来了structuredClone(),一个官方标准、性能可靠的深拷贝方法。 一、 什么是深拷贝,为什么需要它? 首先,我们得搞清楚深拷贝和浅拷贝的区别。 浅拷贝 (Shallow Copy): 创建一个新对象,但新对象的属性仍然是原始对象属性的引用。 也就是说,新对象和原始对象共享同一块内存地址。 修改其中一个对象,另一个对象也会跟着改变。 深拷贝 (Deep Copy): 创建一个全新的对象,并且递归地复制原始对象的所有属性,包括嵌套的对象和数组。 新对象和原始对象完全独立,互不影响。 举个例子: let obj1 = { name: ‘张三’, address: { city: ‘北京’ } }; // 浅拷贝 let obj2 = Object.assign({}, obj1); //或者 …