$ scope。$ watch只触发一次

时间:2016-03-05 18:43:28

标签: javascript angularjs angularjs-watch

我在控制器中设置了以下观察程序:

var embeds = {twitter: false, facebook: false};

$scope.$watch(embeds, function(newVal, oldVal) {
    if(embeds.twitter && embeds.facebook) $scope.loading = appLoader.off();
});

embeds更改时应该触发。我有以下功能,检查我的所有嵌入式推文和Facebook帖子是否已加载到页面。当加载所有推文或Facebook帖子时,它会在embeds块内更新$timeout以触发摘要周期。

checkFBInit();

twttr.ready(function(twttr) {
    twttr.events.bind('loaded', function(event) {
        $timeout(function() {
            embeds.twitter = true;
        });
    });
});

function checkFBInit() {
    // Ensure FB.init has been called before attempting to subscribe to event
    var fbTrys = 0;
    function init() {
        fbTrys++;
        if (fbTrys >= 60) {
            return;
        } else if (typeof(FB) !== 'undefined') {
            fbTrys = 60;
            FB.Event.subscribe('xfbml.render', function() {
                $timeout(function() {
                    embeds.facebook = true;
                });
            });
            return;
        } else {
            init();
        };
    };
    init();
};

我遇到的问题是我的观察者在我设置时只会触发一次。我尝试将embeds绑定到$scope和/或观看embeds.twitterembeds.facebook,但观察者只会触发一次。

1 个答案:

答案 0 :(得分:5)

使用:

$scope.embeds = {twitter: false, facebook: false};
$scope.$watch('embeds', function(newVal, oldVal) {
    if ($scope.embeds.twitter && $scope.embeds.facebook) {
        $scope.loading = appLoader.off();
    }
}, true);

请参阅https://docs.angularjs.org/api/ng/type/ $ rootScope.Scope。第一个参数必须是stringfunction,它返回param的名称。