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

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

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

假设这里有两个对象,一个是 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

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

以上就是JavaScript如何检查一个对象是否为空(代码示例)的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: JavaScript
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:JavaScript如何实现克隆对象?

相关资讯