ECMA 7+ :
// because Object.entries(new Date()).length === 0;
// we have to do some additional check
Object.entries(obj).length === 0 && obj.constructor === Object
ECMA 5+ :
// because Object.keys(new Date()).length === 0;
// we have to do some additional check
Object.keys(obj).length === 0 && obj.constructor === Object
ECMA 5 之前的版本:
function isEmpty(obj) {
for(var prop in obj) {
if(obj.hasOwnProperty(prop)) {
return false;
}
}
return JSON.stringify(obj) === JSON.stringify({});
}
jQuery 的 :
jQuery.isEmptyObject({}); // true
lodash :
_.isEmpty({}); // true
下划线 :
_.isEmpty({}); // true
Hoek.deepEqual({}, {}); // true
Ext.Object.isEmpty({}); // true
angular.equals({}, {}); // true
R.isEmpty({}); // true
没有简单的方法可以做到这一点。您必须显式地遍历属性:
function isEmpty(obj) {
for(var prop in obj) {
if(obj.hasOwnProperty(prop))
return false;
}
return true;
}
如果有ECMAScript 5 支持,则可以改用Object.keys()
:
function isEmpty(obj) {
return Object.keys(obj).length === 0;
}
对于那些同样的问题但使用 jQuery 的人,可以使用jQuery.isEmptyObject 。
这是我的首选解决方案:
var obj = {};
return Object.keys(obj).length; //returns 0 if empty or an integer > 0 if non-empty
您可以使用Underscore.js 。
_.isEmpty({}); // true
if(Object.getOwnPropertyNames(obj).length === 0){
//is empty
}
参见http://bencollier.net/2011/04/javascript-is-an-object-empty/
如何使用 JSON.stringify?它几乎在所有现代浏览器中都可用。
function isEmptyObject(obj){
return JSON.stringify(obj) === '{}';
}
旧的问题,但是有问题。如果您的唯一目的是检查对象是否为空,那么包含 JQuery 并不是一个好主意。相反,深入JQuery 的代码 ,您将得到答案:
function isEmptyObject(obj) {
var name;
for (name in obj) {
if (obj.hasOwnProperty(name)) {
return false;
}
}
return true;
}
我只是遇到了类似情况。我不想使用 JQuery,而是想使用纯 Javascript 做到这一点。
我所做的就是使用以下条件,它对我有用。
var obj = {};
if(JSON.stringify(obj) === '{}') { //This will check if the object is empty
//Code here..
}
对于不等于,请使用以下命令: JSON.stringify(obj) !== '{}'
看看这个JSFiddle
如果您使用的是较新的浏览器,则有一种简单的方法。 Object.keys(obj).length == 0