基于JavaScript判斷兩個(gè)對(duì)象內(nèi)容是否相等
這篇文章主要介紹了基于JavaScript判斷兩個(gè)對(duì)象內(nèi)容是否相等,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
ES6中有一個(gè)方法判斷兩個(gè)對(duì)象是否相等,這個(gè)方法判斷是兩個(gè)對(duì)象引用地址是否一致
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)需求是比較兩個(gè)對(duì)象內(nèi)容是否一致時(shí)就沒用了。
想要比較兩個(gè)對(duì)象內(nèi)容是否一致,思路是要遍歷對(duì)象的所有鍵名和鍵值是否都一致:
1、判斷兩個(gè)對(duì)象是否指向同一內(nèi)存
2、使用Object.getOwnPropertyNames獲取對(duì)象所有鍵名數(shù)組
3、判斷兩個(gè)對(duì)象的鍵名數(shù)組是否相等
4、遍歷鍵名,判斷鍵值是否都相等
let obj1 = { a: 1, b: { c: 2 } } let obj2 = { b: { c: 3 }, a: 1 } function isObjectValueEqual(a, b) { // 判斷兩個(gè)對(duì)象是否指向同一內(nèi)存,指向同一內(nèi)存返回true if (a === b) return true // 獲取兩個(gè)對(duì)象鍵值數(shù)組 let aProps = Object.getOwnPropertyNames(a) let bProps = Object.getOwnPropertyNames(b) // 判斷兩個(gè)對(duì)象鍵值數(shù)組長度是否一致,不一致返回false if (aProps.length !== bProps.length) return false // 遍歷對(duì)象的鍵值 for (let prop in a) { // 判斷a的鍵值,在b中是否存在,不存在,返回false if (b.hasOwnProperty(prop)) { // 判斷a的鍵值是否為對(duì)象,是則遞歸,不是對(duì)象直接判斷鍵值是否相等,不相等返回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)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- AngularJS模糊查詢功能實(shí)現(xiàn)代碼(過濾內(nèi)容下拉菜單排序過濾敏感字符驗(yàn)證判斷后添加表格信息)
- JS判斷兩個(gè)對(duì)象內(nèi)容是否相等的方法示例
- JavaScript判斷數(shù)組重復(fù)內(nèi)容的兩種方法(推薦)
- javascript簡單判斷輸入內(nèi)容是否合法的方法
- JavaScript判斷DIV內(nèi)容是否為空的方法
- js判斷文本框輸入的內(nèi)容是否為數(shù)字
- JS判斷文本框內(nèi)容改變事件的簡單實(shí)例
- js實(shí)現(xiàn)數(shù)組去重、判斷數(shù)組以及對(duì)象中的內(nèi)容是否相同
相關(guān)文章
JavaScript中Object、map、weakmap的區(qū)別分析
這篇文章主要介紹了JavaScript中Object、map、weakmap的區(qū)別分析,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下2020-12-12javascript獲得CheckBoxList選中的數(shù)量
javascript獲得CheckBoxList選中的數(shù)量(jQuery與Javascript對(duì)照學(xué)習(xí)/前臺(tái)與后臺(tái))2009-10-10javascript 原型與原型鏈的理解及應(yīng)用實(shí)例分析
這篇文章主要介紹了javascript 原型與原型鏈的理解及應(yīng)用,結(jié)合實(shí)例形式分析了javascript原型與原型鏈的具體原理、功能、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2020-02-02用JS簡單實(shí)現(xiàn)九宮格抽獎(jiǎng)的示例代碼
在網(wǎng)上經(jīng)常看見一些抽獎(jiǎng)頁面,也玩過不同類型的抽獎(jiǎng)活動(dòng),但是一直沒有做過抽獎(jiǎng)的功能,所以今天來實(shí)現(xiàn)一個(gè)簡單的九宮格抽獎(jiǎng)功能,文中有詳細(xì)的代碼示例供大家參考,感興趣的朋友可以自己動(dòng)手嘗試一下2023-12-12JavaScript中this的全面解析及常見實(shí)例
這篇文章主要給大家介紹了關(guān)于JavaScript中this的全面解析及常見實(shí)例的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05原生JS版和jquery版實(shí)現(xiàn)checkbox的全選/全不選/點(diǎn)選/行內(nèi)點(diǎn)選(Mr.Think)
腳本之家小編之前整理不少checkbox全選全不選這方便的文章,但看了這篇以后發(fā)現(xiàn)實(shí)現(xiàn)方法更好2016-10-10簡單實(shí)現(xiàn)Bootstrap標(biāo)簽頁
這篇文章主要教大家簡單實(shí)現(xiàn)Bootstrap標(biāo)簽頁,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12JS實(shí)現(xiàn)的自定義顯示加載等待圖片插件(loading.gif)
這篇文章主要介紹了JS實(shí)現(xiàn)的自定義顯示加載等待圖片插件,涉及javascript針對(duì)圖片的動(dòng)態(tài)加載實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06