DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS中如何比較兩個Json對象是否相等實例代碼
JS中如何比較兩個Json對象是否相等實例代碼
編輯:關於JavaScript     

在js前端面試過程中,經常會遇到這樣的筆試題:JS中如何比較兩個Json對象是否相等實例代碼,下面小編抽點時間給大家整理下,一起看看吧。

1.先准備三個工具方法,用於判斷是否是對象類型,是否是數組,獲取對象長度

function isObj(object) {
return object && typeof (object) == 'object' && Object.prototype.toString.call(object).toLowerCase() == "[object object]";
}
function isArray(object) {
return object && typeof (object) == 'object' && object.constructor == Array;
}
function getLength(object) {
var count = 0;
for (var i in object) count++;
return count;
}

2.准備兩個相同或不同的Json對象

var jsonObjA = {
"Name": "MyName",
"Company": "MyCompany",
"Infos": [
{ "Age": "100" },
{
"Box": [
{ "Height": "100" },
{ "Weight": "200" }
]
}
],
"Address": "馬欄山"
}
var jsonObjB = {
"Name": "MyName",
"Company": "MyCompany",
"Infos": [
{ "Age": "100" },
{
"Box": [
{ "Height": "100" },
{ "Weight": "200" }
]
}
],
"Address": "馬欄山二號"
}

3.主要的代碼

function Compare(objA, objB) {
if (!isObj(objA) || !isObj(objB)) return false; //判斷類型是否正確
if (getLength(objA) != getLength(objB)) return false; //判斷長度是否一致
return CompareObj(objA, objB, true);//默認為true
}
function CompareObj(objA, objB, flag) {
for (var key in objA) {
if (!flag) //跳出整個循環
break;
if (!objB.hasOwnProperty(key)) { flag = false; break; }
if (!isArray(objA[key])) { //子級不是數組時,比較屬性值
if (objB[key] != objA[key]) { flag = false; break; }
} else {
if (!isArray(objB[key])) { flag = false; break; }
var oA = objA[key], oB = objB[key];
if (oA.length != oB.length) { flag = false; break; }
for (var k in oA) {
if (!flag) //這裡跳出循環是為了不讓遞歸繼續
break;
flag = CompareObj(oA[k], oB[k], flag);
}
}
}
return flag;
}

4.調用方法

var result = Compare(jsonObjA, jsonObjB);
console.log(result); // true or false

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved