美文网首页
JavaScript判断对象是否相等

JavaScript判断对象是否相等

作者: 开飞机的杰瑞 | 来源:发表于2022-03-14 14:20 被阅读0次
    • 方法一

    var obj = {a:'a'}, obj1 = {b:'b'}, obj2 = {a:'a'};
    // 就是使用
    JSON.stringify()
    // 先把对象转化成字符串,
    // 这样就可以啦
    
    console.log(JSON.stringify(obj) == JSON.stringify(obj1));  // false
    console.log(JSON.stringify(obj) == JSON.stringify(obj2));  // true
    

    弊端:这样不是很严谨,如果一个对象里是有两个属性的,只是位置不一样而已,这样的方法就是错误的

    var a ={"name":"lsx","age":12};
    var b ={"age":12,"name":"lsx"};
    
    // 这样就是错误的
    console.log(JSON.stringify(a) == JSON.stringify(b));  // false
    
    • 方法二

    思路: 只要两个对象的名和键值都相同。那么两个对象的内容就相同了
    1、用 Object.getOwnPropertyNames 拿到对象的所有键名数组
    2、比对键名数组的长度是否相等。否 => false。真 => true
    3、比对键名对应的键值是否相等

    function isObjectValueEqual(a, b) {
        var aProps = Object.getOwnPropertyNames(a);
        var bProps = Object.getOwnPropertyNames(b);
    
        if (aProps.length != bProps.length) {
            return false;
        }
    
        for (var i = 0; i < aProps.length; i++) {
            var propName = aProps[i];
            var propA = a[propName];
            var propB = b[propName];
            if ( propA !== propB) {
                return false;
            }
        }
        return true;
    }
    

    弊端:如果 键值也是对象的话,那这个方法就不管用了,比如下面的测试数据

    var a = {
        id:1,
        name:2,
        c: {
            age:3
        }
    };
    var b = {
        id:1,
        name:2,
        c: {
            age:3
        }
    }
    
    // 这样就是错误的
    console.log(isObjectValueEqual(a,b));  // false
    
    • 方法三

    在实现二的基础上递归实现

    isObjectValueEqual(a, b) {
        var aProps = Object.getOwnPropertyNames(a);
        var bProps = Object.getOwnPropertyNames(b);
        if (aProps.length != bProps.length) {
            return false;
        }
        for (var i = 0; i < aProps.length; i++) {
            var propName = aProps[i]
            var propA = a[propName]
            var propB = b[propName]
            if ((typeof (propA) === 'object')) {
                if (this.isObjectValueEqual(propA, propB)) {
                    return true
                } else {
                    return false
                }
            } else if (propA !== propB) {
                return false
            } else {}
        }
        return true
    },
    

    测试

    var a = {
        id:1,
        name:2,
        c: {
            age:3
        }
    };
    var b = {
        id:1,
        name:2,
        c: {
            age:3
        }
    }
    
    // 正确
    console.log(isObjectValueEqual(a,b));  // true
    

    相关文章

      网友评论

          本文标题:JavaScript判断对象是否相等

          本文链接:https://www.haomeiwen.com/subject/biojdrtx.html