objecy.assign是浅克隆还是深克隆?
时间: 2023-12-29 10:04:27 浏览: 26
`Object.assign()` 是浅克隆。在 JavaScript 中,如果对象的属性值是基本数据类型(比如字符串、数字、布尔值等),那么该属性值会被复制到新对象中。但如果对象的属性值是引用类型(比如数组、对象、函数等),那么新对象中的该属性值只是源对象中该属性值的引用,也就是说,源对象和新对象中的该属性值指向同一个内存地址,修改其中一个对象的该属性值会影响另一个对象的该属性值。
下面是一个简单的例子,演示了 `Object.assign()` 的浅克隆特性:
```
let obj1 = {
a: 1,
b: {
c: 2
}
};
let obj2 = Object.assign({}, obj1);
console.log(obj1.b.c); // 输出 2
console.log(obj2.b.c); // 输出 2
obj1.b.c = 3;
console.log(obj1.b.c); // 输出 3
console.log(obj2.b.c); // 输出 3
```
在上面的例子中,我们使用 `Object.assign()` 将 `obj1` 对象浅克隆到 `obj2` 对象中。然后我们修改了 `obj1.b.c` 的值,发现 `obj2.b.c` 的值也被修改了,这是因为 `obj1.b` 和 `obj2.b` 指向同一个对象,所以修改其中一个对象的 `c` 属性值会影响另一个对象的 `c` 属性值。
相关问题
Object.assign()浅拷贝还是深拷贝
Object.assign()是浅拷贝[^1][^2]。
浅拷贝是指在拷贝对象时,只复制对象的引用而不是对象本身。当使用Object.assign()进行拷贝时,如果源对象的属性值是基础类型,那么拷贝的属性值是深拷贝的;但如果源对象的属性值是引用类型,那么拷贝的属性值只是复制了引用,而不是真正的拷贝对象本身,所以是浅拷贝。
举个例子,假设有一个源对象obj,其中有一个属性是引用类型的数组arr:
```javascript
let obj = { arr: [1, 2, 3] };
```
使用Object.assign()进行拷贝:
```javascript
let obj2 = Object.assign({}, obj);
```
此时,obj2中的arr属性与obj中的arr属性指向同一个数组对象,即它们共享同一个引用。如果修改obj2中的arr属性,那么obj中的arr属性也会受到影响,因为它们指向同一个数组对象。
```javascript
obj2.arr.push(4);
console.log(obj.arr); // 输出:[1, 2, 3, 4]
```
所以,Object.assign()是浅拷贝,对于引用类型的属性值只是复制了引用,而不是真正的拷贝对象本身。
Object.assign深拷贝?
Object.assign() 方法是用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它只会拷贝源对象自身的并且可枚举的属性到目标对象上,不会拷贝继承的属性和不可枚举的属性。如果目标对象中的属性具有相同的键,则属性将被源对象中的属性覆盖。需要注意的是,Object.assign() 方法执行的是浅拷贝,即如果源对象的属性值是一个对象或其他引用类型,那么目标对象中对应的属性值也会是这个对象或引用类型的引用,而不是这个对象或引用类型的拷贝。