js浅拷贝和深拷贝的区别及方法

在JavaScript中,拷贝一个对象有两种方式:浅拷贝和深拷贝。它们的区别在于拷贝后的对象与原对象的关系不同。

浅拷贝会创建一个新的对象,但是新对象和原对象的一些属性指向相同的内存地址。也就是说,新对象中的一些属性只是原对象属性的引用。修改新对象中的这些属性也会影响到原对象,因为它们指向同一块内存。常见的浅拷贝方式包括:

扩展运算符(Spread Operator):{...obj}
Object.assign() 方法:Object.assign({}, obj)
Array.prototype.slice() 方法(对于数组):arr.slice()

深拷贝则是完全复制一个对象,包括对象的属性值,而不是仅仅复制对属性的引用。这样,在新对象上做任何修改都不会影响原对象。常见的深拷贝方式包括:

JSON.parse(JSON.stringify()) 方法:JSON.parse(JSON.stringify(obj))
注意:该方法可以实现深拷贝,但有一些限制,例如无法拷贝函数、正则表达式、循环引用等。

递归方法:自定义递归函数来遍历对象的属性,并进行深拷贝。

猜你喜欢

转载自blog.csdn.net/qq_44063746/article/details/130702488