如何使用 JS 動態合併兩個對象的屬性

做者: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引用的對象是一個全新的對象,不會連接到personjob引用的對象。

淺合併和深合併

在淺合併的狀況下,若是源對象上的屬性之一是另外一個對象,則目標對象將包含對源對象中存在的同一對象的引用。 在這種狀況下,不會建立新對象。

咱們調整前面的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

咱們能夠看到personemployee對象中對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... 已收錄,有一線大廠面試完整考點、資料以及個人系列文章。

相關文章
相關標籤/搜索