本文摘自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)
isEmpty(obj2)
isEmpty(obj3)
isEmpty(obj4)
|
??想了半天查看对象是否有 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
}
|

简化版:
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》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » JavaScript如何检查一个对象是否为空(代码示例)