做者:Abhilash Kakumanu
譯者:前端小智
來源:stackak
有夢想,有乾貨,微信搜索 【大遷世界】 關注這個在凌晨還在刷碗的刷碗智。javascript
本文 GitHub https://github.com/qq449245884/xiaozhi 已收錄,有一線大廠面試完整考點、資料以及個人系列文章。前端
咱們可使用擴展操做符(...
)將不一樣的對象合併爲一個對象,這也是合併兩個或多個對象最多見的操做。java
這是一種合併兩個對象的不可變方法,也就是說,用於合併的初始兩個對象不會由於反作用而以任何方式改變。最後,咱們獲得了一個新對象,它由這兩個對象構造而成,而它們仍然保持完整。git
咱們建立兩個對象併合並它們:github
const person = { name: "前端小智", age: 24 } const job = { title: "前端開發", location: "廈門" } const employee = {...person, ...job}; console.log(employee);
運行結果:面試
{ name: '前端小智', age: 24, title: '前端開發', location: '廈門' }
注意:若是這兩個對象之間有共同的屬性,例如它們都有location
,則第二個對象(job
)的屬性將覆蓋第一個對象(person
)的屬性:微信
const person = { name: "前端小智", location: "北京" } const job = { title: "前端開發", location: "廈門" } const employee = {...person, ...job}; console.log(employee);
運行結果:工具
{ name: '前端小智', location: '廈門', title: '前端開發' }
若是要合併兩個以上的對象,最右邊的對象將覆蓋左邊的對象。spa
Object.assign()
合併JavaScript對象並兩個或多個對象的另外一種經常使用方法是使用內置的Object.assign()
方法:debug
Object.assign(target, source1, source2, ...);
此方法將一個或多個源對象中的全部屬性複製到目標對象中。就像擴展操做符同樣,在覆蓋時,將使用最右邊的值:
const person = { name: "前端小智", location: "北京", }; const job = { title: "前端開發", location: "廈門", }; const employee = Object.assign(person, job); console.log(employee);
運行結果:
{ name: '前端小智', age: 24, location: '廈門', title: '前端開發' }
一樣,請記住employee
引用的對象是一個全新的對象,不會連接到person
或job
引用的對象。
在淺合併的狀況下,若是源對象上的屬性之一是另外一個對象,則目標對象將包含對源對象中存在的同一對象的引用。 在這種狀況下,不會建立新對象。
咱們調整前面的person
對象,並將location
做爲對象自己
const person = { name: "John Doe", location: { city: "London", country: "England" } } const job = { title: "Full stack developer" } const employee = {...person, ...job}; console.log(employee.location === person.location);
運行結果:
true
咱們能夠看到person
和employee
對象中對location
對象的引用是相同的。事實上,spread操做符(...
)和Object.assign()
都是淺合併。
JavaScript沒有現成的深合併支持。然而,第三方模塊和庫確實支持它,好比Lodash的.merge
。
本文中,咱們演示在如何在 JS 中合併兩個對象。介紹了spread操做符(...
)和Object.assign()
方法,它們都執行兩個或多個對象的淺合併到一個新對象中,而不會影響組成部分。
~完,我是刷碗智,我要去刷碗了,咱們下期見!
代碼部署後可能存在的BUG無法實時知道,過後爲了解決這些BUG,花了大量的時間進行log 調試,這邊順便給你們推薦一個好用的BUG監控工具 Fundebug。
原文:https://stackak.com/merge-pro...
有夢想,有乾貨,微信搜索 【大遷世界】 關注這個在凌晨還在刷碗的刷碗智。
本文 GitHub https://github.com/qq44924588... 已收錄,有一線大廠面試完整考點、資料以及個人系列文章。