1

我正在尝试在控制器中监听我的注入服务(自我更新)的变化。在下面的示例中,您会发现两种$watch情况 - 一种有效但我不知道确切原因,另一种对我来说很明显但不起作用。第二个例子是正确的方法吗?这不是重复代码吗?正确的方法是什么?

服务:

app.factory("StatsService", [
    '$timeout', 'MockDataService',
    function ($timeout, MockDataService) {
        var service, timeout;
        timeout = 5000;
        service = {
            fetch: function () {
                // Getting sample data, irrelevant, however this is what updates the data
                return this.data = MockDataService.shuffle();
            },
            grab: function () {
                this.fetch();
                return this.update();
            },
            update: function () {
                var _this = this;
                return $timeout(function () {
                    return _this.grab();
                }, timeout);
            }
        };
        service.grab();
        return service;
    }
]);

控制器:

app.controller("StatsController", [
    '$scope', 'StatsService',
    function ($scope, StatsService) {
        var chart;
        $scope.stats = StatsService;
        $scope.test = function (newValue) {
            if (arguments.length === 0) {
                return StatsService.data;
            }
            return StatsService.data = newValue;
        };

        // This doesn't work
        $scope.$watch('stats', function (stats) {
            return console.log('meh');
        });

        // This works, don't know why
        $scope.$watch('test()', function (stats) {
            return console.log('changed');
        });
    }
]);
4

2 回答 2

2

见第三个参数$watchobjectEquality

比较对象是否相等而不是参考。

但是,如果您只对查看返回的数据感兴趣,那么您应该这样做:

$scope.$watch('stats.data', function (stats) {
    return console.log('meh');
});
于 2013-08-21T15:14:13.930 回答
0

你可以使用$rootScope事件。例如,在服务内部,您可以发送一个事件$rootScope.$broadcast("somethingFetched", data)并在控制器中捕获它$scope.$on("somethingFetched", function(event, data) { $scope.data = data })

您可以在文档http://docs.angularjs.org/api/ng .$rootScope.Scope中找到更多详细信息

于 2013-08-21T15:17:58.447 回答