简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

JS中如何比较两个Json对象是否相等实例代码

来源:易贤网   阅读:3344 次  日期:2016-07-27 15:56:19

温馨提示:易贤网小编为您整理了“JS中如何比较两个Json对象是否相等实例代码”,方便广大网友查阅!

在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

更多信息请查看网络编程
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:AngularJS实用开发技巧(推荐)
下一篇:js实现可键盘控制的简单抽奖程序
易贤网手机网站地址:JS中如何比较两个Json对象是否相等实例代码
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!