阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

ES6 判断是否为空对象

82次阅读
没有评论

共计 964 个字符,预计需要花费 3 分钟才能阅读完成。

导读 在 js 中判断对象是否为空,是十分常见的操作,那么在 ES6 中有哪些写法呢?
ES6 Object.keys()

Object.keys() 是 ES6 中的新方法, 返回值也是对象中属性名组成的数组,包括对象自身的(不含继承的)所有可枚举属性(不含 Symbol 属性)的键名。

Object.keys(obj).length === 0 && obj.constructor === Object  // true 表示为空对象,false 为非空对象 

缺点:部分浏览器不支持,需要通过 babel 类插件转为 ES5。使用范例如下:

var data = {};

var arr = Object.keys(data);

alert(arr.length == 0);//true 即为空对象

var datas={a:1,b:2};

var aRR = Object.keys(datas);

console.log(aRR) -->   ['a','b']
将 json 对象转化为 json 字符串,再判断该字符串是否为 ”{}”
var data = {};
var b = (JSON.stringify(data) == "{}");
alert(b);//true
for in 循环判断
var obj = {};
var b = function() {for(var key in obj) {return false;}
 return true;
}
alert(b());//true
jquery isEmptyObject()

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

var data = {};
var b = $.isEmptyObject(data);
alert(b);//true
Object.getOwnPropertyNames()

此方法是使用 Object 对象的 getOwnPropertyNames 方法,获取到对象中的属性名,存到一个数组中,返回数组对象,我们可以通过判断数组的 length 来判断此对象是否为空。

注意:此方法不兼容 ie8,其余浏览器没有测试。

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

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-25发表,共计964字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中