js判断空对象

1. 使用 Object.keys() 方法

Object.keys(obj) 方法返回一个包含对象可枚举属性名称的数组。如果返回的数组长度为 0,表示对象为空。

javascript 复制代码
const isEmpty = (obj) => Object.keys(obj).length === 0;

// 示例
const emptyObject = {};
const nonEmptyObject = { key: 'value' };

console.log(isEmpty(emptyObject)); // true
console.log(isEmpty(nonEmptyObject)); // false

2. 使用 Object.entries() 方法

Object.entries(obj) 返回一个包含对象自身可枚举属性 [key, value] 对的数组。如果该数组长度为 0,则对象为空。

javascript 复制代码
const isEmpty = (obj) => Object.entries(obj).length === 0;

// 示例
console.log(isEmpty({})); // true
console.log(isEmpty({ a: 1 })); // false

3. 使用 JSON.stringify() 方法

通过将对象序列化为 JSON 字符串,判断其是否为 {}

javascript 复制代码
const isEmpty = (obj) => JSON.stringify(obj) === '{}';

// 示例
console.log(isEmpty({})); // true
console.log(isEmpty({ a: 1 })); // false

4. 使用 for...in 循环结合hasOwnProperty函数

使用 for...in 循环遍历对象,如果能够找到一个可枚举的属性,则对象不为空。注意:这会遍历对象的原型链上的可枚举属性。

javascript 复制代码
const isEmpty = (obj) => {
  for (let key in obj) {
    // 如果有可枚举属性,返回 false
    if (obj.hasOwnProperty(key)) {
      return false; // 非空对象
    }
  }
  return true; // 空对象
};

// 示例
console.log(isEmpty({})); // true
console.log(isEmpty({ a: 1 })); // false

5. 结合 Object.getOwnPropertyNames()Object.getOwnPropertySymbols()

可以使用 Object.getOwnPropertyNames(obj)Object.getOwnPropertySymbols(obj) 方法(分别返回对象的可枚举和不可枚举属性,及符号属性)来判断。

javascript 复制代码
const isEmpty = (obj) => 
  Object.getOwnPropertyNames(obj).length === 0 && 
  Object.getOwnPropertySymbols(obj).length === 0;

// 示例
console.log(isEmpty({})); // true
console.log(isEmpty({ a: 1 })); // false

总结

  • 最常用且推荐的方法是使用 Object.keys(),因为它简洁且句意明确。
  • Object.entries()JSON.stringify() 也很常见,适用于不同场景。
  • for...in 循环适合需要检查可枚举属性的情况。
  • 使用原生的 Object.getOwnPropertyNames()Object.getOwnPropertySymbols() 方法更为全面。
相关推荐
沿着路走到底13 分钟前
JS事件循环
java·前端·javascript
Hard but lovely20 分钟前
C++11: 自定义异常&&标准异常体系&&回顾c异常处理方式
开发语言·c++
子春一231 分钟前
Flutter 2025 可访问性(Accessibility)工程体系:从合规达标到包容设计,打造人人可用的数字产品
前端·javascript·flutter
白兰地空瓶37 分钟前
别再只会调 API 了!LangChain.js 才是前端 AI 工程化的真正起点
前端·langchain
六bring个六43 分钟前
文件压缩处理(一)
开发语言·c#
Chrikk1 小时前
现代化 C++ 工程构建:CMake 与包管理器的依赖治理
开发语言·c++
jlspcsdn2 小时前
20251222项目练习
前端·javascript·html
行走的陀螺仪2 小时前
Sass 详细指南
前端·css·rust·sass
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ2 小时前
React 怎么区分导入的是组件还是函数,或者是对象
前端·react.js·前端框架
世转神风-2 小时前
qt-kits-警告:No C++ compiler,无法正常解析工程项目.pro文件
开发语言·c++