91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript中如何動態合并兩個對象的屬性

發布時間:2021-05-14 10:42:35 來源:億速云 閱讀:454 作者:小新 欄目:web開發

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

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

這是一種合并兩個對象的不可變方法,也就是說,用于合并的初始兩個對象不會因為副作用而以任何方式改變。最后,我們得到了一個新對象,它由這兩個對象構造而成,而它們仍然保持完整。

我們創建兩個對象并合并它們:

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

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

console.log(employee);

運行結果:

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

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

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

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

console.log(employee);

運行結果:

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

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

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

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

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

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

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

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

運行結果:

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

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

淺合并和深合并

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

我們調整前面的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

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

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

JavaScript的特點

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

以上是“javascript中如何動態合并兩個對象的屬性”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

闻喜县| 措美县| 肇东市| 嫩江县| 临武县| 溆浦县| 灌南县| 延庆县| 平塘县| 张家港市| 奉贤区| 两当县| 东兴市| 永宁县| 安阳市| 榆林市| 武强县| 闽侯县| 梁河县| 抚宁县| 农安县| 桐柏县| 安乡县| 鄂州市| 襄城县| 四平市| 准格尔旗| 南靖县| 嘉荫县| 元氏县| 吉木乃县| 周至县| 民县| 大田县| 布拖县| 揭西县| 新余市| 双柏县| 盐城市| 大新县| 巴林右旗|