如何使用 JS 動態合并兩個對象的屬性
我們可以使用擴展操作符(...)將不同的對象合并為一個對象,這也是合并兩個或多個對象最常見的操作。
這是一種合并兩個對象的不可變方法,也就是說,用于合并的初始兩個對象不會因為副作用而以任何方式改變。最后,我們得到了一個新對象,它由這兩個對象構造而成,而它們仍然保持完整。
我們創建兩個對象并合并它們:
- 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: '前端開發'
- }
如果要合并兩個以上的對象,最右邊的對象將覆蓋左邊的對象。
使用 Object.assign() 合并JavaScript對象
并兩個或多個對象的另一種常用方法是使用內置的Object.assign()方法:
- 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()方法,它們都執行兩個或多個對象的淺合并到一個新對象中,而不會影響組成部分。
~完,我是刷碗智,我要去刷碗了,我們下期見!
作者:Abhilash Kakumanu 譯者:前端小智 來源:stackak
原文:https://stackak.com/merge-properties-of-two-objects-dynamically-in-javascript/
本文轉載自微信公眾號「大遷世界」,可以通過以下二維碼關注。轉載本文請聯系大遷世界公眾號。