前言:在实现业务逻辑的过程中,很多工程师都会遇到需要判断一个对象,数组是否为空的情景,很多时候我们在请求数据的时候都需要判断请求的对象数据是否为空,如果直接使用,在数据请求为空时,控制台就会报错。因此我们需要给一个判断,如果数据存在就直接调用,不存在就创建空的对象/数组。下面狗尾草给大家整理了几种判断对象是否为空的方法,希望对大家有帮助。
1.我们在需要请求对象/数组的下标或属性来判断是否为空
var oData = Obj.item !=="undefined" ? Obj.item : {}
2.将json对象转化为json字符串,再判断该字符串是否为"{}"
var data = {}; var b = (JSON.stringify(data) == "{}"); alert(b);//true
3.for in 循环判断
var obj = {}; var b = function() { for(var key in obj) { return false; } return true; } alert(b());//true
4.jquery的isEmptyObject方法
此方法是jquery将方法3(for in)进行封装,使用时需要依赖jquery
var data = {}; var b = $.isEmptyObject(data); alert(b);//true
5.Object.getOwnPropertyNames()方法
此方法是使用Object对象的getOwnPropertyNames方法,获取到对象中的属性名,存到一个数组中,返回数组对象,我们可以通过判断数组的length来判断此对象是否为空
注意:此方法不兼容ie8,其余浏览器没有测试
var data = {}; var arr = Object.getOwnPropertyNames(data); alert(arr.length == 0);//true
6.使用ES6的Object.keys()方法
与方法5类似,是ES6的新方法, 返回值也是对象中属性名组成的数组
var data = {}; var arr = Object.keys(data); alert(arr.length == 0);//true
以上就是狗尾草结合开发遇到的问题和大牛们的经验总结的判断JavaScript是否为空的方法,下一篇狗尾草会总结有关判断数组是否为空的方法。总结不易,有错记得评论提醒哦,狗尾草和大家共同进步。