JS对象判空的几种方式,你真的会了吗?

JS对象判空的几种方式,你真的会了吗?前言 为什么空对象检测如此重要 在开发中我们经常会遇到这样的场景 if isEmpty userInfo 跳转登录页 四种主流检测方案对比方案一 Object keys 基础版 function isEmpty obj re

欢迎大家来到IT世界,在知识的湖畔探索吧!

前言:为什么空对象检测如此重要?

在开发中我们经常会遇到这样的场景:

if(isEmpty(userInfo)){ // 跳转登录页 }

欢迎大家来到IT世界,在知识的湖畔探索吧!

四种主流检测方案对比

方案一:Object.keys() 基础版

欢迎大家来到IT世界,在知识的湖畔探索吧!function isEmpty(obj) { return Object.keys(obj).length === 0; }

适用场景:普通数据对象检测

致命缺陷

  • 漏检不可枚举属性
  • 无视Symbol类型键值
  • 对特殊对象处理不当
function isEmpty(obj) { return JSON.stringify(obj) === '{}'; } 

三大隐患

  1. 过滤undefined和函数属性
  2. 无法处理循环引用
  3. Date/RegExp等对象误判

方案三:Reflect.ownKeys() 终极方案

欢迎大家来到IT世界,在知识的湖畔探索吧!function isStrictEmpty(obj) { return Reflect.ownKeys(obj).length === 0; }

核心优势

  • 捕获所有类型键值(含Symbol)
  • 检测不可枚举属性

方案四:for…in 循环法(不推荐)

function isEmptyLoop(obj) { for(let key in obj){ if(obj.hasOwnProperty(key)) return false; } return true; }

重大缺陷

  • 可能误判原型链属性
  • 性能最差(平均慢3倍)

方法对比表格

方法

Symbol 键

不可枚举属性

原型链属性

特殊对象处理

Object.keys()

JSON.stringify()

Reflect.ownKeys()

for…in + 检查

核心API深度对比:Object.keys vs Reflect.ownKeys

欢迎大家来到IT世界,在知识的湖畔探索吧!const secretKey = Symbol('SECRET'); const obj = { [secretKey]: '绝密数据', 2: '数字键', 'name': '张三' }; Object.defineProperty(obj, 'hiddenProp', { value: '隐藏属性', enumerable: false }); console.log('Object.keys:', Object.keys(obj)); // 输出: ['2', 'name'] console.log('Reflect.ownKeys:', Reflect.ownKeys(obj)); // 输出: ['2', 'name', 'hiddenProp', Symbol(SECRET)]

Object.keys 与 Reflect.ownKeys 的核心区别

示例说明

JS对象判空的几种方式,你真的会了吗?



欢迎大家来到IT世界,在知识的湖畔探索吧!

性能实测数据

通过Benchmark.js测试10万次操作:

JS对象判空的几种方式,你真的会了吗?

常见误区警示

  1. 数组误判问题
isEmpty([]) // 返回true,但空数组≠空对象!

2.特殊对象陷阱

欢迎大家来到IT世界,在知识的湖畔探索吧!isEmpty(new Date()) // 多数方案返回true

3.循环引用崩溃

js const obj = { self: null }; obj.self = obj; JSON.stringify(obj); // 抛出异常

最佳实践推荐

欢迎大家来到IT世界,在知识的湖畔探索吧!// 通用场景检测 const safeIsEmpty = obj => { return Object.prototype.toString.call(obj) === '[object Object]' && Object.keys(obj).length === 0; } // 严格模式检测 const strictIsEmpty = obj => { return Reflect.ownKeys(obj).length === 0 && Object.getPrototypeOf(obj) === Object.prototype; }

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/129917.html

(0)
上一篇 44分钟前
下一篇 12分钟前

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信