JavaScript判断对象是否相等

  • 方法一

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判断对象是否相等)