1.for...in
function checkObj (obj) {
for(let i in obj) {
return false
}
return true
}
let obj = {}
console.log(checkObj(obj))// true
let obj = {a:1}
console.log(checkObj(obj))// false
for...in可以遍历原型上的属性,所以注意到这点
let obj = {a:1}
let obj1 = Object.create(obj)
console.log(obj1) // {}
console.log(checkObj(obj1)) // false
2.JSON.stringify()
(此方法有一定的漏洞且耗时)
注意:
1. 非数组对象的属性不能保证以特定的顺序出现在序列化后的字符串中。
2. 布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值。
3. undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成null(出现在数组中时)。
4. 所有以symbol为属性键的属性都会被完全忽略掉,即便replacer参数中强制指定包含了它们。
5. 不可枚举的属性会被忽略
let obj = {}
if (JSON.stringify(obj) === '{}') {
return true //是空对象
}
const a = {a: undefined}
let b = JSON.stringify(a)
console.log(b) //{}
const a = {a: ()=> {}}
let b = JSON.stringify(a)
console.log(b) //{}
3.Object.keys()
function checkObj(obj) {
let arr = Object.keys(obj)
return arr.length > 0?false:true
}
4.Object.getOwnPropertyNames()
(最优选择)
与Object.keys()
区别:Object.keys()
返回可枚举的,Object.getOwnPropertyNames()
返回所有的(可枚举和不可枚举,但是不包括Symbol)
let obj = {};
let arr = Object.getOwnPropertyNames(obj);
console.log( arr.length == 0 ); //true