基于JavaScript判斷兩個對象內容是否相等
這篇文章主要介紹了基于JavaScript判斷兩個對象內容是否相等,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
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
當需求是比較兩個對象內容是否一致時就沒用了。
想要比較兩個對象內容是否一致,思路是要遍歷對象的所有鍵名和鍵值是否都一致:
1、判斷兩個對象是否指向同一內存
2、使用Object.getOwnPropertyNames獲取對象所有鍵名數組
3、判斷兩個對象的鍵名數組是否相等
4、遍歷鍵名,判斷鍵值是否都相等
let obj1 = { a: 1, b: { c: 2 } } let obj2 = { b: { c: 3 }, a: 1 } function isObjectValueEqual(a, b) { // 判斷兩個對象是否指向同一內存,指向同一內存返回true if (a === b) return true // 獲取兩個對象鍵值數組 let aProps = Object.getOwnPropertyNames(a) let bProps = Object.getOwnPropertyNames(b) // 判斷兩個對象鍵值數組長度是否一致,不一致返回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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JavaScript中Object、map、weakmap的區(qū)別分析
這篇文章主要介紹了JavaScript中Object、map、weakmap的區(qū)別分析,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下2020-12-12原生JS版和jquery版實現(xiàn)checkbox的全選/全不選/點選/行內點選(Mr.Think)
腳本之家小編之前整理不少checkbox全選全不選這方便的文章,但看了這篇以后發(fā)現(xiàn)實現(xiàn)方法更好2016-10-10JS實現(xiàn)的自定義顯示加載等待圖片插件(loading.gif)
這篇文章主要介紹了JS實現(xiàn)的自定義顯示加載等待圖片插件,涉及javascript針對圖片的動態(tài)加載實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-06-06