JavaScript

超轻量级php框架startmvc

如何检查一个对象是否为空

更新时间:2020-08-21 10:48:01 作者:startmvc
检查一个数组为空很容易,直接调用length方法即可,那么如何检查一个对象是否为空呢Ϯ

检查一个数组为空很容易,直接调用 length 方法即可,那么如何检查一个对象是否为空呢 ❓

这里的空指的是对象没有自有属性

假设这里有两个对象,一个是 obj 一个是 anotherObj


let obj1 = {
 name: 'oli',
 child: {
 name: 'oliver'
 }
}

let obj2 = {
 [Symbol('name')]: 'alice'
}

let obj3 = Object.defineProperty({}, 'name', {
 value: 'alice',
 enumerable: false
})

let obj4 = Object.create(null)

// 我们需要一个函数,判断是否不含自有属性

isEmpty(obj1) // false
isEmpty(obj2) // false
isEmpty(obj3) // false
isEmpty(obj4) // true

想了半天查看对象是否有 Symbol 属性只能使用 getOwnPropertySymbols 方法,如果还有更好的方法欢迎留言

方法一:遍历

for-in 遍历,并通过 hasOwnProperty 方法确认是否存在某个 key 这种方法不能够遍历到 enumerable 为 false 的属性


const isEmptyObj = object => {
 if (!!Object.getOwnPropertySymbols(object).length) {
 return false
 }
 for (const key in object) {
 if (object.hasOwnProperty(key)) {
 return false
 }
 }
 return true
}

方法二:keys 方法

使用 Object 静态方法 keys 然后判断 length 即可,keys 返回的是自身可枚举属性,因此同样的不可遍历到 enumerable 为 false 的属性


const isEmptyObj = object => {
 if (!!Object.getOwnPropertySymbols(object).length) {
 return false
 }
 if (Object.keys(object).length) {
 return false
 }
 return true
}

方法三:JSON 方法

使用 JSON Stringify 方法将对象转为字符串,与字符串 '{}' 对比,同样该方法无法获取到不可遍历属性


const isEmptyObj = object => {
 if (!!Object.getOwnPropertySymbols(object).length) {
 return false
 }
 return JSON.stringify(object) === '{}'
}

。

方法四:getOwnPropertyNames 方法

使用 Object 的 getOwnPropertyNames 方法,获取所有属性名,这样就算是不可枚举属性依然能够获取到,算是比较 ok 的方法。


const isEmptyObj = object => {
 if (!!Object.getOwnPropertySymbols(object).length) {
 return false
 }
 if (!!Object.getOwnPropertyNames(object).length) {
 return false
 }
 return true
}

简化版:


const isEmptyObj = object => !Object.getOwnPropertySymbols(object).length && !Object.getOwnPropertyNames(object).length

以上所述是小编给大家介绍的js如何检查一个对象是否为空详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

js判断对象是否为空 js判断对象为空 js判断对象是否为空的方法