日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何使用JS動態(tài)合并兩個對象的屬性

我們可以使用擴(kuò)展操作符(...)將不同的對象合并為一個對象,這也是合并兩個或多個對象最常見的操作。

這是一種合并兩個對象的不可變方法,也就是說,用于合并的初始兩個對象不會因為副作用而以任何方式改變。最后,我們得到了一個新對象,它由這兩個對象構(gòu)造而成,而它們?nèi)匀槐3滞暾?/p>

我們創(chuàng)建兩個對象并合并它們:

 
 
 
 
  1. const person = { 
  2.     name: "前端小智", 
  3.     age: 24 
  4. const job = { 
  5.     title: "前端開發(fā)", 
  6.     location: "廈門" 
  7.  
  8. const employee = {...person, ...job}; 
  9.  
  10. console.log(employee); 

運行結(jié)果:

 
 
 
 
  1. {  
  2.   name: '前端小智',  
  3.   age: 24,  
  4.   title: '前端開發(fā)',  
  5.   location: '廈門'  

注意:如果這兩個對象之間有共同的屬性,例如它們都有l(wèi)ocation,則第二個對象(job)的屬性將覆蓋第一個對象(person)的屬性:

 
 
 
 
  1. const person = { 
  2.   name: "前端小智", 
  3.   location: "北京" 
  4. const job = { 
  5.   title: "前端開發(fā)", 
  6.   location: "廈門" 
  7.  
  8. const employee = {...person, ...job}; 
  9.  
  10. console.log(employee); 

運行結(jié)果:

 
 
 
 
  1. {  
  2.   name: '前端小智',  
  3.   location: '廈門',  
  4.   title: '前端開發(fā)'  

如果要合并兩個以上的對象,最右邊的對象將覆蓋左邊的對象。

使用 Object.assign() 合并JavaScript對象

并兩個或多個對象的另一種常用方法是使用內(nèi)置的Object.assign()方法:

 
 
 
 
  1. Object.assign(target, source1, source2, ...); 

此方法將一個或多個源對象中的所有屬性復(fù)制到目標(biāo)對象中。就像擴(kuò)展操作符一樣,在覆蓋時,將使用最右邊的值:

 
 
 
 
  1. const person = { 
  2.   name: "前端小智", 
  3.   location: "北京", 
  4. }; 
  5. const job = { 
  6.   title: "前端開發(fā)", 
  7.   location: "廈門", 
  8. }; 
  9.  
  10. const employee = Object.assign(person, job); 
  11. console.log(employee); 

運行結(jié)果:

 
 
 
 
  1. {  
  2.   name: '前端小智',  
  3.   age: 24, 
  4.   location: '廈門',  
  5.   title: '前端開發(fā)'  

同樣,請記住employee引用的對象是一個全新的對象,不會鏈接到person或job引用的對象。

淺合并和深合并

在淺合并的情況下,如果源對象上的屬性之一是另一個對象,則目標(biāo)對象將包含對源對象中存在的同一對象的引用。在這種情況下,不會創(chuàng)建新對象。

我們調(diào)整前面的person對象,并將location作為對象本身

 
 
 
 
  1. const person = { 
  2.     name: "John Doe", 
  3.     location: { 
  4.         city: "London",  
  5.         country: "England" 
  6.     } 
  7. const job = { 
  8.     title: "Full stack developer" 
  9.  
  10. const employee = {...person, ...job}; 
  11.  
  12. console.log(employee.location === person.location); 

運行結(jié)果:

 
 
 
 
  1. true 

我們可以看到person和employee對象中對location對象的引用是相同的。事實上,spread操作符(...)和Object.assign() 都是淺合并。

JavaScript沒有現(xiàn)成的深合并支持。然而,第三方模塊和庫確實支持它,比如Lodash的.merge。

總結(jié)

本文中,我們演示在如何在 JS 中合并兩個對象。介紹了spread操作符(...)和Object.assign()方法,它們都執(zhí)行兩個或多個對象的淺合并到一個新對象中,而不會影響組成部分。

~完,我是刷碗智,我要去刷碗了,我們下期見!

作者:Abhilash Kakumanu 譯者:前端小智 來源:stackak

原文:https://stackak.com/merge-properties-of-two-objects-dynamically-in-javascript/

本文轉(zhuǎn)載自微信公眾號「大遷世界」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系大遷世界公眾號。


分享名稱:如何使用JS動態(tài)合并兩個對象的屬性
網(wǎng)頁網(wǎng)址:http://www.dlmjj.cn/article/djdigpc.html