我在控制器中设置了以下观察程序:
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.twitter
和embeds.facebook
,但观察者只会触发一次。
答案 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。第一个参数必须是string
或function
,它返回param的名称。