溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2021-05-14 10:42:35 來源:億速云 閱讀:453 作者:小新 欄目:web開發(fā)

小編給大家分享一下javascript中如何動(dòng)態(tài)合并兩個(gè)對(duì)象的屬性,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

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

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

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

const person = {
    name: "前端小智",
    age: 24
}
const job = {
    title: "前端開發(fā)",
    location: "廈門"
}

const employee = {...person, ...job};

console.log(employee);

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

{ 
  name: '前端小智', 
  age: 24, 
  title: '前端開發(fā)', 
  location: '廈門' 
}

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

const person = {
  name: "前端小智",
  location: "北京"
}
const job = {
  title: "前端開發(fā)",
  location: "廈門"
}

const employee = {...person, ...job};

console.log(employee);

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

{ 
  name: '前端小智', 
  location: '廈門', 
  title: '前端開發(fā)' 
}

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

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

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

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

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

const person = {
  name: "前端小智",
  location: "北京",
};
const job = {
  title: "前端開發(fā)",
  location: "廈門",
};

const employee = Object.assign(person, job);
console.log(employee);

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

{ 
  name: '前端小智', 
  age: 24,
  location: '廈門', 
  title: '前端開發(fā)' 
}

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

淺合并和深合并

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

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

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

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

true

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

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

JavaScript的特點(diǎn)

1.JavaScript主要用來向HTML頁面添加交互行為。 2.JavaScript可以直接嵌入到HTML頁面,但寫成單獨(dú)的js文件有利于結(jié)構(gòu)和行為的分離。 3.JavaScript具有跨平臺(tái)特性,在絕大多數(shù)瀏覽器的支持下,可以在多種平臺(tái)下運(yùn)行。

以上是“javascript中如何動(dòng)態(tài)合并兩個(gè)對(duì)象的屬性”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI