JavaScript如何检查一个对象是否为空(代码示例)


本文摘自PHP中文网,作者不言,侵删。

本篇文章给大家带来的内容是关于JavaScript如何检查一个对象是否为空(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

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

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

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

1

2

3

4

5

6

7

8

9

10

11

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

1

2

3

4

5

6

7

8

9

const isEmptyObj = object => {

    if (!!Object.getOwnPropertySymbols(object).length) {

        return false

    }

    if (Object.keys(object).length) {

        return false

    }

    return true

}

方法三:JSON 方法

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

1

2

3

4

5

6

const isEmptyObj = object => {

    if (!!Object.getOwnPropertySymbols(object).length) {

        return false

    }

    return JSON.stringify(object) === '{}'

}

方法四:getOwnPropertyNames 方法

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

1

2

3

4

5

6

7

8

9

const isEmptyObj = object => {

    if (!!Object.getOwnPropertySymbols(object).length) {

        return false

    }

    if (!!Object.getOwnPropertyNames(object).length) {

        return false

    }

    return true

}

3161390651-5ca22e351ac38_articlex.png

简化版:

1

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

【相关推荐:JavaScript视频教程】

以上就是JavaScript如何检查一个对象是否为空(代码示例)的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

javascript有几个对话框

屏蔽javascript会怎样

详解javascript的空值合并运算符(??)

编写一个javascript程序来列出javascript对象的属性

javascript如何实现submit功能

javascript深入探索 websocket和http/2与sse +如何选择正确的路径!

javascript实现双向链表(代码示例)

javascript中amd和es6模块导入导出的比较(代码示例)

前端工程师需要掌握哪些知识?

javascript中如何判断函数、变量是否存在

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...