检查对象是否为空,使用ng-show但不能使用控制器?

问题描述 投票:98回答:9

我有一个像这样声明的JS对象

$scope.items = {};

我还有一个$ http请求,用项目填充此对象。我想检测这个项目是否为空,看来ng-show支持这个...我输入

ng-show="items"

并且神奇地它可以工作,我也想从控制器做同样的事情,但我似乎无法让它工作,似乎我可能必须迭代对象,看看它是否有任何属性或使用lodash或下划线。

还有其他选择吗?

我确实试过了

alert($scope.items == true);

但是当创建对象并填充$http时,它总是返回false,所以它不会那样工作。

angularjs angularjs-scope
9个回答
62
投票

这里不需要使用空对象文字,可以使用null或undefined:

$scope.items = null;

通过这种方式,ng-show应该继续工作,在你的控制器中你可以做到:

if ($scope.items) {
    // items have value
} else {
    // items is still null
}

在您的$http回调中,您执行以下操作:

$http.get(..., function(data) {
    $scope.items = {
        data: data,
        // other stuff
    };
});

198
投票

或者你可以通过做这样的事情来保持简单:

alert(angular.equals({}, $scope.items));

71
投票

在一个私人项目中,写了这个过滤器

angular.module('myApp')
    .filter('isEmpty', function () {
        var bar;
        return function (obj) {
            for (bar in obj) {
                if (obj.hasOwnProperty(bar)) {
                    return false;
                }
            }
            return true;
        };
    });

用法:

<p ng-hide="items | isEmpty">Some Content</p>

测试:

describe('Filter: isEmpty', function () {

    // load the filter's module
    beforeEach(module('myApp'));

    // initialize a new instance of the filter before each test
    var isEmpty;
    beforeEach(inject(function ($filter) {
        isEmpty = $filter('isEmpty');
    }));

    it('should return the input prefixed with "isEmpty filter:"', function () {
          expect(isEmpty({})).toBe(true);
          expect(isEmpty({foo: "bar"})).toBe(false);
    });

});

问候。


59
投票

另一个简单的单线程:

var ob = {};
Object.keys(ob).length // 0

27
投票

如果您不能将OBJ等于null,则可以执行以下操作:

$scope.isEmpty = function (obj) {
    for (var i in obj) if (obj.hasOwnProperty(i)) return false;
    return true;
};

在视图中你可以做到:

<div ng-show="isEmpty(items)"></div>

你可以做

var ob = {};
Object.keys(ob).length

仅当您的浏览器支持ECMAScript 5时。例如,IE 8不支持此功能。

有关更多信息,请参阅http://kangax.github.io/compat-table/es5/


7
投票
if( obj[0] )

更简洁的版本可能是:

if( typeof Object.keys(obj)[0] === 'undefined' )

如果没有设置对象属性,结果将是未定义的。


6
投票

或者,如果使用lo-dash:_.empty(value)。

“检查值是否为空。长度为0的数组,字符串或参数对象以及没有自己的可枚举属性的对象被视为”空“。


-1
投票

检查空对象

$scope.isValid = function(value) {
    return !value
}

-11
投票

你可以检查物品的长度

ng-show="items.length"
© www.soinside.com 2019 - 2024. All rights reserved.