0

我有一个小应用程序从 signalR 获取数据并将它们从工厂传回控制器。但是当 rootScope 触发并将对象传递到范围时,此数据会在视图上更新。这是我的控制器代码:

(function () {
'use strict';

angular.module('app.config', ['datatables'])
    //.controller('configCtrl', configCtrl)
    .value('backendServerUrl', 'https://pmscsds01.azurewebsites.net/')
    .controller('sysCtrl', [
        "$scope", "$http", "DataConfig", "backendHubProxy", "$rootScope", function ($scope, $http, DataConfig, backendHubProxy, $rootScope) {
            DataConfig.GetConfigs();
            $rootScope.$on('data-ready', function (event, args) {
                $scope.systems = args.data;
                backendHubProxy.initalizeHub('configurationStatusClientHub', args.pcellId, $scope.systems);
            });

            $rootScope.$on('data-changed', function (event, args) {
                $scope.systems = args;
            });
        }
    ]);})();

第一个 $rootScope.$on 工作正常,但第二个:

$rootScope.$on('data-changed', function (event, args) {
                $scope.systems = args;
            });

不是,它会将新的更新数据传递给系统范围,但这不会反映在视图上。

4

1 回答 1

0

我终于解决了这个问题,只是添加了 $scope.apply();

$rootScope.$on('data-changed', function (event, args) {
            $scope.systems = args;
            $scope.apply();
        });

现在它起作用了;)

于 2016-02-20T10:12:03.683 回答