内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

怎么使用JS動態(tài)合并兩個對象的屬性

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

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

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

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

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

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

運行結果:

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

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

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

運行結果:

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

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

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

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

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

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

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

運行結果:

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

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

淺合并和深合并

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

我們調(diào)整前面的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沒有現(xiàn)成的深合并支持。然而,第三方模塊和庫確實支持它,比如Lodash的.merge。

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

標題名稱:怎么使用JS動態(tài)合并兩個對象的屬性
網(wǎng)頁路徑:http://www.rwnh.cn/article20/gdddjo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設計公司、手機網(wǎng)站建設、網(wǎng)站內(nèi)鏈云服務器、品牌網(wǎng)站建設、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
通许县| 武汉市| 邳州市| 娄底市| 吕梁市| 大渡口区| 岢岚县| 武定县| 喀喇沁旗| 阿鲁科尔沁旗| 金昌市| 鹿泉市| 余干县| 通河县| 贵溪市| 香格里拉县| 孟连| 庄浪县| 万州区| 台北市| 昭觉县| 淳安县| 巴林右旗| 上饶县| 多伦县| 固原市| 酒泉市| 安庆市| 广丰县| 方正县| 珲春市| 景谷| 建平县| 偏关县| 河北省| 盈江县| 临澧县| 罗江县| 麦盖提县| 新和县| 昌吉市|