网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的考试资料:

 

标题 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
随便看

 

在线学习网考试资料包含高考、自考、专升本考试、人事考试、公务员考试、大学生村官考试、特岗教师招聘考试、事业单位招聘考试、企业人才招聘、银行招聘、教师招聘、农村信用社招聘、各类资格证书考试等各类考试资料。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/20 9:47:52