1

我在我的控制器中设置了以下观察者:

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但观察者只触发一次。

4

1 回答 1

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。第一个参数必须是stringorfunction返回参数的名称。

于 2016-03-05T18:48:21.907 回答