真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

這篇文章給大家分享的是有關(guān)怎么使用JS動(dòng)態(tài)合并兩個(gè)對(duì)象的屬性的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)公司于2013年開始,先為蕉城等服務(wù)建站,蕉城等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為蕉城企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

我們可以使用擴(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ì)象之間有共同的屬性,例如它們都有l(wèi)ocation,則第二個(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ì)鏈接到person或job引用的對(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

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

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

感謝各位的閱讀!關(guān)于“怎么使用JS動(dòng)態(tài)合并兩個(gè)對(duì)象的屬性”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!


網(wǎng)站欄目:怎么使用JS動(dòng)態(tài)合并兩個(gè)對(duì)象的屬性
標(biāo)題來源:http://weahome.cn/article/gdddjo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部