JS判斷兩個(gè)對(duì)象內(nèi)容是否相等的方法示例
本文實(shí)例講述了JS判斷兩個(gè)對(duì)象內(nèi)容是否相等的方法。分享給大家供大家參考,具體如下:
我們知道,如果兩個(gè)對(duì)象即使內(nèi)容,JavaScript也會(huì)判斷它們不相等。但是有時(shí)候,我們僅僅需要判斷兩個(gè)對(duì)象的內(nèi)容是否相等。那么我們應(yīng)該如何做到且考慮周全呢?比如說(shuō)0和-0,null和undefined,是不相等的,NaN和NaN默認(rèn)是不相等的。我寫(xiě)了一個(gè)isEqual方法,考慮到了諸多方面,代碼如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> </head> <body> </body> <script type="text/javascript"> //isEqual:判斷兩個(gè)對(duì)象是否鍵值對(duì)應(yīng)相等 function isEqual(a,b){ //如果a和b本來(lái)就全等 if(a===b){ //判斷是否為0和-0 return a !== 0 || 1/a ===1/b; } //判斷是否為null和undefined if(a==null||b==null){ return a===b; } //接下來(lái)判斷a和b的數(shù)據(jù)類型 var classNameA=toString.call(a), classNameB=toString.call(b); //如果數(shù)據(jù)類型不相等,則返回false if(classNameA !== classNameB){ return false; } //如果數(shù)據(jù)類型相等,再根據(jù)不同數(shù)據(jù)類型分別判斷 switch(classNameA){ case '[object RegExp]': case '[object String]': //進(jìn)行字符串轉(zhuǎn)換比較 return '' + a ==='' + b; case '[object Number]': //進(jìn)行數(shù)字轉(zhuǎn)換比較,判斷是否為NaN if(+a !== +a){ return +b !== +b; } //判斷是否為0或-0 return +a === 0?1/ +a === 1/b : +a === +b; case '[object Date]': case '[object Boolean]': return +a === +b; } //如果是對(duì)象類型 if(classNameA == '[object Object]'){ //獲取a和b的屬性長(zhǎng)度 var propsA = Object.getOwnPropertyNames(a), propsB = Object.getOwnPropertyNames(b); if(propsA.length != propsB.length){ return false; } for(var i=0;i<propsA.length;i++){ var propName=propsA[i]; //如果對(duì)應(yīng)屬性對(duì)應(yīng)值不相等,則返回false if(a[propName] !== b[propName]){ return false; } } return true; } //如果是數(shù)組類型 if(classNameA == '[object Array]'){ if(a.toString() == b.toString()){ return true; } return false; } } //test var obj1={name:"liu",age:22}; var obj2={name:"liu",age:22}; var obj3={name:"liu",age:33}; var state1=isEqual(obj1,obj2); var state2=isEqual(obj1,obj3); console.log(state1);//true console.log(state2);//false var state3=isEqual(null,undefined); console.log(state3);//false var state4=isEqual(NaN,NaN); console.log(state4);//true var arr1=[1,2,3]; var arr2=[1,2,3]; var arr3=[1,23]; var state5=isEqual(arr1,arr2); console.log(state5);//true var state6=isEqual(arr1,arr3); console.log(state6);//false </script> </html>
運(yùn)行效果圖如下:
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript中json操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫(huà)特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- AngularJS模糊查詢功能實(shí)現(xiàn)代碼(過(guò)濾內(nèi)容下拉菜單排序過(guò)濾敏感字符驗(yàn)證判斷后添加表格信息)
- JavaScript判斷數(shù)組重復(fù)內(nèi)容的兩種方法(推薦)
- javascript簡(jiǎn)單判斷輸入內(nèi)容是否合法的方法
- JavaScript判斷DIV內(nèi)容是否為空的方法
- js判斷文本框輸入的內(nèi)容是否為數(shù)字
- JS判斷文本框內(nèi)容改變事件的簡(jiǎn)單實(shí)例
- js實(shí)現(xiàn)數(shù)組去重、判斷數(shù)組以及對(duì)象中的內(nèi)容是否相同
- 基于JavaScript判斷兩個(gè)對(duì)象內(nèi)容是否相等
相關(guān)文章
js實(shí)現(xiàn)表單提交后不重新刷新當(dāng)前頁(yè)面
本文介紹了如何通過(guò)js實(shí)現(xiàn)表單提交后不重新刷新當(dāng)前頁(yè)面的方法實(shí)例.既提交了FORM保存了數(shù)據(jù),頁(yè)面也不會(huì)跳轉(zhuǎn),很實(shí)用。需要的朋友可以參考下2016-11-11js遍歷json對(duì)象所有key及根據(jù)動(dòng)態(tài)key獲取值的方法(必看)
下面小編就為大家?guī)?lái)一篇js遍歷json對(duì)象所有key及根據(jù)動(dòng)態(tài)key獲取值的方法(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03iframe與主框架跨域相互訪問(wèn)實(shí)現(xiàn)方法
今天正好需要用到iframe 與主框架相互訪問(wèn)的實(shí)現(xiàn)方法,正好看到了這篇文章,確實(shí)不錯(cuò),特分享一下,需要的朋友可以參考下2017-09-09JavaScript隨機(jī)打亂數(shù)組順序之隨機(jī)洗牌算法
這篇文章主要介紹了JavaScript隨機(jī)打亂數(shù)組順序之隨機(jī)洗牌算法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08使用純?cè)鶭S實(shí)現(xiàn)大文件分片上傳
前段時(shí)間在工作中接觸到了文件上傳的內(nèi)容,但業(yè)務(wù)中實(shí)現(xiàn)的功能比較簡(jiǎn)單,于是我想著能不能使用純?cè)姆绞綄?shí)現(xiàn)一個(gè)大文件的上傳DEMO,從而在本質(zhì)上學(xué)習(xí)大文件上傳的思路,本教程使用純?cè)膆tml+node.js實(shí)現(xiàn),需要的朋友可以參考下2024-06-06