0

0

如何使用 JavaScript 检查对象是否为空?

王林

王林

发布时间:2023-09-14 14:17:02

|

1620人浏览过

|

来源于tutorialspoint

转载

如何使用 javascript 检查对象是否为空?

在 JavaScript 中,对象是最重要的数据类型,我们在使用 JavaScript 框架开发应用程序时大部分时间都需要它。有时,我们需要检查一个对象是否为空,并根据对象值执行操作。

例如,您正在从数据库中获取数据;如果没有找到,你可以获得一个空对象。当您对空对象执行某些操作或执行某些方法时,它会在程序中引发错误。因此,最好先检查对象是否为空。

我们将学习三种使用 JavaScript 检查对象是否为空的方法。

使用Object.keys()方法

我们可以使用Object.keys()方法来获取单个数组中对象的键。之后,我们可以使用数组的 length 属性检查数组的长度。如果键数组的长度为0,则意味着该对象不包含任何键,并且该对象为空。

立即学习Java免费学习笔记(深入)”;

语法

用户可以按照下面的语法使用Object.keys()方法检查对象是否为空。

let obj1Len = Object.keys(obj1).length;
if (obj1Len == 0) {
   
   // object is empty
} else {
   
   // object is not empty
} 

在上面的语法中,Object.keys()返回obj1的所有键的数组,我们使用length属性来获取它的长度。使用上面的语法,我们可以使用 Object.keys() 方法获取所有键的数组,并且我们还可以使用 length 属性检查数组的长度

示例

在下面的示例中,我们创建了两个不同的对象。 obj1 包含一些属性,而 obj2 为空且不包含任何单个属性。

之后,我们对两个对象使用 Object.keys() 方法来获取键数组并检查数组的长度以确保对象为空或至少包含一个属性。

<html>
<body>
   <h3>Using the<i> object.keys() </i>method to check whether the object contains some value or not</h3>
   <p id = "output"> </p>
   <script>
      let output = document.getElementById("output");
      let obj1 = {
         prop1: 10,
         prop2: "Hi",
      };
      let obj2 = {};
      
      // get the array of all keys using the Object.keys() method,
      
      // check the length of the array using the length property
      let obj1Len = Object.keys(obj1).length;
      if (obj1Len != 0) {
         output.innerHTML += "The value of obj1 is " + JSON.stringify(obj1) + "</br>";
      } else {
         output.innerHTML += "The obj1 object is empty! </br>";
      }
      let obj2Len = Object.keys(obj2).length;
      if (obj2Len != 0) {
         output.innerHTML += "The value of obj1 is " + obj2 + "</br>";
      } else {
         output.innerHTML += "The obj2 object is empty! </br>"; 
      }
   </script>
</body>
</html>

使用 for-in 循环

for-in 循环允许我们迭代对象的键。我们可以使用 for-in 循环遍历对象的每个键。在这里,我们将使用 for-in 循环并检查如果它对对象进行了一次迭代,则该对象至少包含一个属性并且不为空。

语法

用户可以按照以下语法使用 for-in循环检查对象是否为空。

ImgGood
ImgGood

免费在线AI照片编辑器

下载
function isObjectEmpty(object) {
   for (ele in object) {
      
      // object is not empty
      return;
   }
   
   // if control comes here, the object is empty
} 

在上面的语法中,如果发生了 for 循环的单次迭代,则意味着我们已经确保该对象至少包含一个属性。因此,我们在 for-in 循环的第一次迭代之后使用 return 关键字终止该函数。

示例

在下面的示例中,我们创建了两个不同的对象。此外,我们还创建了 isObjectEmpty() 函数,该函数根据对象是否为空打印不同的消息。

我们使用不同的对象调用了isObjectEmpty()函数两次,用户可以观察其输出。

<html>
<body>
   <h3>Using the <i>for-in loop</i> to check whether the object contains some value.</h3>
   <p id="output"></p>
   <script>
      let output = document.getElementById("output");
      
      // creating the objects
      let obj1 = {
         prop1: false,
      };
      let obj2 = {};
      
      // creating a function to check object is empty or not
      function isObjectEmpty(object) {
         for (ele in object) {
            
            // if any single iteration occurs using a for-in loop, it means the object contains at least one property
            output.innerHTML += "The object " + JSON.stringify(object) + " is not empty! </br>";
            return;
         }
         output.innerHTML += "The object " + JSON.stringify(object) + " is empty! </br>";
      }
      
      // calling the isObjectEmpty() function by passing different objects as an argument
      isObjectEmpty(obj1);
      isObjectEmpty(obj2);
   </script> 
</body>
</html>

使用 JSON.stringify() 方法

JSON.stringify() 方法将任何值转换为我们作为该方法的参数传递的字符串。空对象的语法类似于 {},stringify() 方法总是返回空对象的“{}”。

因此,我们可以将 stringify() 方法的返回值与“{}”进行比较,确定该对象是否为空。

语法

用户可以按照以下语法使用 JSON.stringify() 方法检查对象是否为空。

if(JSON.stringify(education) == "{}") {
   
   // object is empty
} else {
   
   // object is not empty
}

在上述语法中,如果 education 对象为空,JSON.stringify() 方法将返回“{}”。

示例

在下面的示例中,我们创建了 education 对象,其中包含一些属性。因此,JSON.stringify()方法不会返回“{}”,但会返回 education 对象的字符串值。因此,用户可以观察到显示教育对象不为空的输出。

<html>
<body> 
   <h3> Using the<i> JSON.stringify() method </i> to check whether object contains some value or not.</h3>
   <p id="output"></p>
   <script>
      let output = document.getElementById("output");
      
      // creating the objects
      let education = {
         totalYears: 12,
         school: "Online",
      };
      
      // convert object to string,
      
      // if object is empty, the JSON.stringify() method will return "{}"
      if (JSON.stringify(education) == "{}") {
         output.innerHTML += "Object is empty!";
      } else {
         output.innerHTML += "Education object is not empty!";
      }
   </script>
</body>
</html>

我们学习了三种检查对象是否为空的方法。第一种和第三种方法只有一行代码;用户需要编写 3 到 4 行才能使用第二行。因此,最好使用第一种和第三种方法中的任何一种,以获得更好的代码可读性。

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

338

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

225

2025.10.31

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

138

2026.02.12

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号