协慌网

登录 贡献 社区

如何测试空的 JavaScript 对象?

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

var a = {};

我怎样才能检查是否是这种情况?

答案

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

ExtJS 的

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

AngularJS(版本 1)

angular.equals({}, {}); // true

Ramda

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