基于JavaScript判斷兩個對象內(nèi)容是否相等
這篇文章主要介紹了基于JavaScript判斷兩個對象內(nèi)容是否相等,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
ES6中有一個方法判斷兩個對象是否相等,這個方法判斷是兩個對象引用地址是否一致
let obj1= { a: 1 } let obj2 = { a: 1 } console.log(Object.is(obj1, obj2)) // false let obj3 = obj1 console.log(Object.is(obj1, obj3)) // trueconsole.log(Object.is(obj2, obj3)) // false
當(dāng)需求是比較兩個對象內(nèi)容是否一致時就沒用了。
想要比較兩個對象內(nèi)容是否一致,思路是要遍歷對象的所有鍵名和鍵值是否都一致:
1、判斷兩個對象是否指向同一內(nèi)存
2、使用Object.getOwnPropertyNames獲取對象所有鍵名數(shù)組
3、判斷兩個對象的鍵名數(shù)組是否相等
4、遍歷鍵名,判斷鍵值是否都相等
let obj1 = { a: 1, b: { c: 2 } } let obj2 = { b: { c: 3 }, a: 1 } function isObjectValueEqual(a, b) { // 判斷兩個對象是否指向同一內(nèi)存,指向同一內(nèi)存返回true if (a === b) return true // 獲取兩個對象鍵值數(shù)組 let aProps = Object.getOwnPropertyNames(a) let bProps = Object.getOwnPropertyNames(b) // 判斷兩個對象鍵值數(shù)組長度是否一致,不一致返回false if (aProps.length !== bProps.length) return false // 遍歷對象的鍵值 for (let prop in a) { // 判斷a的鍵值,在b中是否存在,不存在,返回false if (b.hasOwnProperty(prop)) { // 判斷a的鍵值是否為對象,是則遞歸,不是對象直接判斷鍵值是否相等,不相等返回false if (typeof a[prop] === 'object') { if (!isObjectValueEqual(a[prop], b[prop])) return false } else if (a[prop] !== b[prop]) { return false } } else { return false } } return true } console.log(isObjectValueEqual(obj1, obj2)) // false
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:沒有了
欄 目:JavaScript
下一篇:沒有了
本文標題:基于JavaScript判斷兩個對象內(nèi)容是否相等
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9230.html
您可能感興趣的文章
- 04-02javascript潛力,javascript強大嗎
- 04-02javascript點線,點線的代碼
- 04-02javascript移出,js 移入移出
- 04-02javascript替換字符串,js字符串的替換
- 04-02包含javascript舍的詞條
- 04-02javascript匿名,js匿名方法
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript警報,JavaScript警告
- 04-02javascript前身,javascript的前身
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁面


閱讀排行
本欄相關(guān)
- 04-02javascript點線,點線的代碼
- 04-02javascript潛力,javascript強大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報,JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁面
- 04-02javascript前身,javascript的前身
隨機閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)
- 01-10delphi制作wav文件的方法