JS判断对象是否为空对象{}

小计一个知识点,有时候我们想判断对象是否为空对象,也就是没有任何属性的对象{},
什么?你想用

obj == null

?,
别闹了,很明显我不是这个意思。

什么?你又想用这个?

obj == {
    
    }

算了,给你看一段代码:

let obj={
    
    };
return obj == {
    
    }

这段代码返回true了么?眼尖的同学应该能一眼看出来,别看这两对花括号长得一模一样,但是肯定返回false,为什么,我说得详细点:
在JavaScript中,当你创建一个空对象 let obj = {},然后比较该对象是否等于另一个空对象 {} 时,将返回 false。这是因为在JavaScript中,对象的比较是基于引用的,而不是基于内容的。
两个不同的对象即使具有相同的内容,它们也被认为是不相等的,因为它们在内存中具有不同的引用地址。

其实这行代码在什么情况下都不会为true,那我怎么判断这个对象是不是空对象呢?有以下几个方法:
方法一(推荐)、要验证一个对象是否为空对象,你可以使用 Object.keys(obj) 来检查它是否具有任何属性。

let obj = {
    
    };
let isEmpty = Object.keys(obj).length === 0;
console.log(isEmpty); // true

方法二(不推荐)、你也可以使用 JSON.stringify(obj) 来将对象转换为字符串,然后检查字符串是否为 “{}” 来判断对象是否为空对象。但请注意,这种方法可能不适用于包含函数或循环引用的对象。

let obj = {
    
    };
let isEmpty = JSON.stringify(obj) === "{}";
console.log(isEmpty); // true

别看了赶紧收藏下来啦,我又不会删文章放心啦。

猜你喜欢

转载自blog.csdn.net/Spy003/article/details/132014152