自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何使用 JS 動(dòng)態(tài)合并兩個(gè)對(duì)象的屬性

開發(fā) 前端
我們可以使用擴(kuò)展操作符(...)將不同的對(duì)象合并為一個(gè)對(duì)象,這也是合并兩個(gè)或多個(gè)對(duì)象最常見的操作。

[[397766]]

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

這是一種合并兩個(gè)對(duì)象的不可變方法,也就是說(shuō),用于合并的初始兩個(gè)對(duì)象不會(huì)因?yàn)楦弊饔枚匀魏畏绞礁淖儭W詈?,我們得到了一個(gè)新對(duì)象,它由這兩個(gè)對(duì)象構(gòu)造而成,而它們?nèi)匀槐3滞暾?/p>

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

  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); 

運(yùn)行結(jié)果:

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

注意:如果這兩個(gè)對(duì)象之間有共同的屬性,例如它們都有l(wèi)ocation,則第二個(gè)對(duì)象(job)的屬性將覆蓋第一個(gè)對(duì)象(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); 

運(yùn)行結(jié)果:

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

如果要合并兩個(gè)以上的對(duì)象,最右邊的對(duì)象將覆蓋左邊的對(duì)象。

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

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

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

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

  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); 

運(yùn)行結(jié)果:

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

同樣,請(qǐng)記住employee引用的對(duì)象是一個(gè)全新的對(duì)象,不會(huì)鏈接到person或job引用的對(duì)象。

淺合并和深合并

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

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

  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); 

運(yùn)行結(jié)果:

  1. true 

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

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

總結(jié)

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

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

作者:Abhilash Kakumanu 譯者:前端小智 來(lái)源:stackak

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

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

 

責(zé)任編輯:武曉燕 來(lái)源: 大遷世界
相關(guān)推薦

2022-06-17 09:46:51

Chrome 102Chrome瀏覽器

2021-08-03 08:13:47

數(shù)據(jù)

2022-06-27 07:50:16

鏈表節(jié)點(diǎn)測(cè)試

2021-01-28 08:20:41

鏈表空間復(fù)雜度

2009-06-30 09:37:02

對(duì)象比較Java

2023-10-04 20:03:46

GOkeyvalue

2018-09-04 12:03:31

HBase大數(shù)據(jù)存儲(chǔ)

2020-08-14 08:13:49

列表差異編程

2020-10-29 08:39:45

JSONJava對(duì)象

2011-08-29 18:17:58

Ubuntu

2024-02-28 08:10:15

Linux靜態(tài)庫(kù)動(dòng)態(tài)庫(kù)

2023-09-12 08:19:48

接口Controller線程

2020-06-22 08:41:34

JS語(yǔ)言代碼

2010-07-13 10:56:43

Perl print

2021-10-15 06:58:41

psycopg2綠色版 Python

2016-08-22 13:04:36

2010-08-19 11:22:19

marginpadding

2021-12-01 07:31:50

Java文件校驗(yàn)

2010-07-02 12:26:51

LEACH協(xié)議

2009-07-15 18:29:22

Jython應(yīng)用
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)