如何测试一个空的 JavaScript 对象?

在 AJAX 请求之后,有时我的应用程序可能返回一个空对象,例如:

var a = {};

如何检查情况呢?

答案

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

ek

Hoek.deepEqual({}, {}); // true

ExtJS

Ext.Object.isEmpty({}); // true

AngularJS(版本 1)

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