使用 JSON.stringify()方法,将对象转化为字符串。然后使用 “===” 判断即可:
let obj1 = {
a: 1,
b: 2
}
let obj2 = {
a: 1,
b: 2,
}
console.log(JSON.stringify(obj1) === JSON.stringify(obj2)) // true
此方法看似简单,但是存在较大的缺点,比如上面代码稍微变化下,输出结果就变为 false。
let onj1 = {
a: 1,
b: 2
}
let onj2 = {
b: 2,
a: 1
}
console.log(JSON.stringify(onj1) === JSON.stringify(onj2)) // false
onj1和onj2的键、值是相同的,但是调整了键的位置后,就会发现上面使用JSON.stringify()
方法存在问题,主要是转化为字符串后,比较时是按照字符串下边去对比每一个下标对应的字符是否相等,所以这种方法在比较对象的时候局限性较大,故使用是需要谨慎!!!
由于对象是由键值对构成的,那要判断对象相等,只要判断两个对象的键、值是否都相同,如果相同就代表它们相等,反之不相等。
思路:
let onj1 = {
a: 1,
b: 2
}
let onj2 = {
b: 2,
a: 1
}
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;
}
console.log(isObjectValueEqual(onj1, onj2)) // true
function isObjectValueEqualNew(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.isObjectValueEqualNew(propA, propB)) {
return true
} else {
return false
}
} else if (propA !== propB) {
return false
} else {
//
}
}
return true
}
let obb1 = {
a: 1,
b: 2,
c: {
d: 4,
e: {
f: 5,
e: 6
}
}
}
let obb2 = {
b: 2,
a: 1,
c: {
e: {
e: 6,
f: 5
},
d: 4
}
}
console.log(isObjectValueEqualNew(obb1, obb2)) // true
至此,就可以判断两个对象是否相等了!
如果您有更好的方法,欢迎留言讨论~~~