Question

J'ai une usine avec une promesse censée interroger les données d'un service Web à un intervalle de 5 secondes.Les données doivent être récupérées par un contrôleur et analysées.L'interrogation est lancée à partir de app.run.

Le problème est que les données ne semblent pas accessibles depuis le contrôleur, pourquoi ?

(Juste en le regardant, je commence à me demander si la variable LiveData est threadsafe)

   factory('liveDataPoller', ['$http', '$timeout', function($http, $timeout) {
        var liveData = {
                status: -1,
                events: [],
                checksum: 0,
                serverTime: 0,
                calls: 0
            };
        var poller = function() {
                $http.get('/api/getInformation.json')
                    .then(function(res) {

                        status = res.statusCode;

                        if(status < 0) {
                            // TODO: handle service error
                        } else {
                            liveData.events = res.events;
                            liveData.checksum = res.checksum;
                            liveData.serverTime = res.serverTime;
                        }

                        liveData.status = status;

                        liveData.calls++;

                        $timeout(poller, 5000);
                    });
            };

        poller();

        return {
            getData: function() {
                return liveData;
            }
        };
    }])

Le controlle:

angular.module('myApp.controllers', [])
    .controller('MainCtrl', ['$rootScope', '$scope', '$timeout', 'liveDataPoller', function($rootScope, $scope, $timeout, liveDataPoller) {

           var transformLiveData = function(liveData) {
                var liveDataObj = {
                        serverTime: liveData.serverTime,
                        checksum: liveData.checksum,
                        events: [],
                        calls: liveData.calls
                    },
                    events = [],
                    i;

                if(liveData.events) {
                    for(i = 0; i < liveData.events.length; i++) {
                        events.push({
                            id:                 liveData.events[i].id,
                            name:               liveData.events[i].details[1],
                            freeText:           liveData.events[i].details[2],
                        });
                    }

                    liveDataObj.events = events;
                }

                return liveDataObj;
            }

        $rootScope.liveData = transformLiveData(liveDataPoller.getData());


    }])
Était-ce utile?

La solution

Le problème est que la ligne qui renvoie liveData à votre service exécuté lorsque le $http l'appel est en cours, je envelopperais le liveData objet autour d’une promesse et travaillez avec cette promesse dans le contrôleur.Ou, à l'approche d'un pauvre, vous pourriez regarder le liveData objet dans votre contrôleur :

$scope.$watch(liveDataPoller.getData,function(value){
    console.log(value);
},true)
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top