1. 官方解釋是這樣子的:?Object.assign()?方法用于將所有可枚舉屬性的值從一個(gè)或多個(gè)源對(duì)象復(fù)制到目標(biāo)對(duì)象。它將返回目標(biāo)對(duì)象。
舉例子:
const? obj = { name: '簡(jiǎn)書', type:1 };
const obj2 = Object.assign({}, obj, {name: '簡(jiǎn)書2'});
那么 obj2 就會(huì)覆蓋obj 的name 但是不會(huì)改變?cè)衞bj 的值。
如果在 obj 的基礎(chǔ)上增加一個(gè)對(duì)象,看例子:
obj.typeObj = { age: 12 };
const obj3 = Object.assign({}, obj);
當(dāng)我們改變 obj時(shí), 會(huì)發(fā)生什么變化?
我們來改變一下
obj.typeObj.age = 15?
consle.log(obj3.typeObj.age)? ? // 結(jié)果是? ?15?
一直以為它是一個(gè)深拷貝。。。無知的我。
如果需要深度拷貝還是用 JSON.parse(JSON.stringfy(obj)) 先把對(duì)象轉(zhuǎn)成字符串,再轉(zhuǎn)成對(duì)象。