JavaScript – 具有服务器发送事件的AngularJS

前端之家收集整理的这篇文章主要介绍了JavaScript – 具有服务器发送事件的AngularJS前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个AngularJS应用程序与以下控制器.它在正常的 JSON资源和手动请求更新的GET工作正常,但我不能使其与服务器发送的事件一起工作.我遇到的问题是,在收到SSE事件并设置/更新openListingsReport变量后,我的视图没有得到更新.我显然缺少一个非常基本的概念.请帮我解决这个问题.
var rpCtrl = angular.module('rpCtrl',['rpSvc']);

rpCtrl.controller('rpOpenListingsCtrl',['$scope','rpOpenListingsSvc',function ($scope,rpOpenListingsSvc) {
        $scope.updating = false;

        if (typeof(EventSource) !== "undefined") {
            // Yes! Server-sent events support!
            var source = new EventSource('/listings/events');

            source.onmessage = function (event) {
                $scope.openListingsReport = event.data;
                $scope.$apply();
                console.log($scope.openListingsReport);
            };
        }
    } else {
        // Sorry! No server-sent events support..
        alert('SSE not supported by browser.');
    }

    $scope.update = function () {
        $scope.updateTime = Date.now();
        $scope.updating = true;
        rpOpenListingsSvc.update();
    }

    $scope.reset = function () {
        $scope.updating = false;
    }
}]);

解决方法

问题出在如下:
$scope.openListingsReport = event.data;

应该是:

$scope.openListingsReport = JSON.parse(event.data);

猜你在找的JavaScript相关文章