JS判斷兩個對象內(nèi)容是否相等的方法示例
本文實例講述了JS判斷兩個對象內(nèi)容是否相等的方法。分享給大家供大家參考,具體如下:
我們知道,如果兩個對象即使內(nèi)容,JavaScript也會判斷它們不相等。但是有時候,我們僅僅需要判斷兩個對象的內(nèi)容是否相等。那么我們應(yīng)該如何做到且考慮周全呢?比如說0和-0,null和undefined,是不相等的,NaN和NaN默認(rèn)是不相等的。我寫了一個isEqual方法,考慮到了諸多方面,代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
</body>
<script type="text/javascript">
//isEqual:判斷兩個對象是否鍵值對應(yīng)相等
function isEqual(a,b){
//如果a和b本來就全等
if(a===b){
//判斷是否為0和-0
return a !== 0 || 1/a ===1/b;
}
//判斷是否為null和undefined
if(a==null||b==null){
return a===b;
}
//接下來判斷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;
}
//如果是對象類型
if(classNameA == '[object Object]'){
//獲取a和b的屬性長度
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];
//如果對應(yīng)屬性對應(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動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
JS中touchstart事件與click事件沖突的解決方法
這篇文章主要給大家介紹了關(guān)于JS中touchstart事件與click事件沖突的解決方法,文中通過示例代碼將解決的方法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03
Javascript動態(tài)創(chuàng)建div的方法
這篇文章主要介紹了Javascript動態(tài)創(chuàng)建div的方法,是javascript節(jié)點(diǎn)操作的典型應(yīng)用,非常具有實用價值,需要的朋友可以參考下2015-02-02
javascript html實現(xiàn)網(wǎng)頁版日歷代碼
這篇文章主要介紹了javascript html實現(xiàn)網(wǎng)頁版日歷代碼,需要的朋友可以參考下2016-03-03
javascript 對象數(shù)組根據(jù)對象object key的值排序
本文僅僅是實現(xiàn)了javascript 對象數(shù)組根據(jù)對象object key的值排序,算是對自己學(xué)習(xí)javascript這么久的一個小結(jié),希望大家能夠喜歡2015-03-03
JS定時檢測任務(wù)任務(wù)完成后執(zhí)行下一步的解決辦法
這篇文章主要介紹了JS定時檢測任務(wù)任務(wù)完成后執(zhí)行下一步的解決辦法,需要的朋友可以參考下2016-12-12

