24

我目前正在开发基于 Web 的 twitter 客户端,因此我使用了 angular.js、node.js 和 socket.io。我通过 socket.io 将新推文推送到我的客户端,服务等待新推文。当一条新推文到达时,服务会通过 $broadcast 发送一个事件。

在我的控制器中是一个事件侦听器,其中传入的推文正在一个单独的函数中处理。这个函数只是将新推文推送到我的推文范围内。

现在,我的问题是,我的观点没有更新,但我可以看到我的范围在扩大。也许你们中的一个人有一个想法,我该如何解决这个问题?

另外我的代码:

服务:

(function () {
    app.factory('Push', ['$rootScope', function ($rootScope) {
        socket.on('new-tweet', function (msg) {
            $rootScope.$broadcast('new-tweet', msg);
        });
    }]);
}());

控制器:

(function () {
    app.controller("StreamCtrl", function StreamCtrl ($scope, $rootScope, $http, Push) {
        $scope.tweets = [];

        $http
            .get('/stream')
            .then(function (res) {
                $scope.tweets = res.data;
            });

        $scope.addTweet = function (data) {
            $scope.tweets.push(data);
            console.log($scope.tweets);
        };

        $rootScope.$on('new-tweet', function (event, data) {
            if (!data.friends) {
                $scope.addTweet(data);
            }
        });
    });
}());

整个项目在这里:https ://github.com/hochitom/node-twitter-client

4

2 回答 2

49

在 addTweet 中添加下面的代码行,问题就解决了

$scope.addTweet = function (data) {
            $scope.tweets.push(data);
            $scope.$apply();
            console.log($scope.tweets);
        };
于 2013-04-24T09:06:37.867 回答
1

我更喜欢使用$timeout(不要忘记将其注入您的控制器)而不是$apply

 app.controller("StreamCtrl", function StreamCtrl ($scope, $timeout $rootScope, $http, Push) {

    //...

    $scope.addTweet = function (data) {
        $timeout(function() {
            $scope.tweets.push(data);
            console.log($scope.tweets);
        });
    };

    //...

});
于 2017-11-18T20:25:18.797 回答