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

20190401232110.png

⭐️ 更多前端技术和知识点,搜索订阅号 JS 菌 订阅前端

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

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

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

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 方法,若是还有更好的方法欢迎留言spa

方法一:遍历

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

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 的属性cdn

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 的方法。blog

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

20190401230821.png

简化版:字符串

const isEmptyObj = object => !Object.getOwnPropertySymbols(object).length && !Object.getOwnPropertyNames(object).length
复制代码

JS 菌公众帐号

若是有更好的方法欢迎留言

请关注个人订阅号,不按期推送有关 JS 的技术文章,只谈技术不谈八卦 😊

EOF