唯品秀前端博客
当前位置: 前端开发 > JavaScript > js判断对象是否为空对象的几种方法

js判断对象是否为空对象的几种方法

2019-06-04 分类:JavaScript 作者:管理员 阅读(3825)

在做数据交互的时候,我们经常需要判断数据或者对象是不是为空,避免当接口异常时候前端页面崩溃,上次总结了篇关于如何判断数据是不是数组,下面来自网上一篇教程总结方便以后查阅,正所谓好记性不如烂笔头。

1.将json对象转化为json字符串,再判断该字符串是否为"{}"

1
2
3
var data = {};
var b = (JSON.stringify(data) == "{}");
alert(b);//true

2.for in 循环判断

1
2
3
4
5
6
7
8
var obj = {};
var b = function() {
for(var key in obj) {
return false;
}
return true;
}
alert(b());//true

3.jquery的isEmptyObject方法

此方法是jquery将2方法(for in)进行封装,使用时需要依赖jquery

1
2
3
var data = {};
var b = $.isEmptyObject(data);
alert(b);//true

4.Object.getOwnPropertyNames()方法

此方法是使用Object对象的getOwnPropertyNames方法,获取到对象中的属性名,存到一个数组中,返回数组对象,我们可以通过判断数组的length来判断此对象是否为空,注意:此方法不兼容ie8,其余浏览器没有测试

1
2
3
var data = {};
var arr = Object.getOwnPropertyNames(data);
alert(arr.length == 0);//true

5.使用ES6的Object.keys()方法

与4方法类似,是ES6的新方法, 返回值也是对象中属性名组成的数组

1
2
3
var data = {};
var arr = Object.keys(data);
alert(arr.length == 0);//true

小结

综上来看,应该说第一种方法是最简单最容易理解的,第五种的话也不错,其他方案多少有些复杂,当然,也可以项目中写个通用方法去判断。

「两年博客,如果觉得我的文章对您有用,请帮助本站成长」

赞(1) 打赏

谢谢你请我吃鸡腿*^_^*

支付宝
微信
1

谢谢你请我吃鸡腿*^_^*

支付宝
微信

上一篇:

下一篇:

你可能感兴趣

共有 2 条评论 - js判断对象是否为空对象的几种方法

  1. 时光 Windows 7 搜狗浏览器 2.X

    来了一次又一次,总是情不自已!

    1. 唯品秀前端技术博客 Windows NT Chrome 57.0.2987.98

      @时光时光时光慢些吧,不要再让你们变老了。。。

博客简介

唯品秀博客: weipxiu.com,一个关注Web前端开发技术、关注用户体验、坚持更多原创实战教程的个人网站,愿景:成为宇宙中最具有代表性的前端博客,期待您的参与,主题源码 

精彩评论

友情链接

他们同样是一群网虫,却不是每天泡在网上游走在淘宝和网游之间、刷着本来就快要透支的信用卡。他们或许没有踏出国门一步,但同学却不局限在一国一校,而是遍及全球!申请交换友链

站点统计

  • 文章总数: 243 篇
  • 草稿数目: 0 篇
  • 分类数目: 15 个
  • 独立页面: 6 个
  • 评论总数: 905 条
  • 链接总数: 14 个
  • 标签总数: 433 个
  • 建站时间: 1066 天
  • 注册用户: 3708 人
  • 访问总量: 8696407 次
  • 最近更新: 2019年11月14日
服务热线:
 173xxxx7240

 QQ在线交流

 旺旺在线