【发布时间】:2012-11-15 12:06:12
【问题描述】:
我遇到了 $rootScope.$broadcast 事件没有被触发的问题:
App.run(function($rootScope){
var text = 'Not So Static Now';
$rootScope.$broadcast('event:staticText', text);
}).$inject = ['$rootScope'];
App.controller('Ctrl1', function($scope, $rootScope) {
$scope.staticText = "Static Text";
var things = [
'AngularJS',
'StackOverflow',
'JSFiddle'
];
$scope.$emit('event:things', things);
$scope.$on('event:staticText', function(e, args){
$scope.staticText = args;
});
}).$inject = ['$scope', '$rootScope'];
以上内容应该将 {{staticText}} 输出更改为“Not so Static Now”,但事实并非如此。
我创建了一个 JSFiddle 来演示问题http://jsfiddle.net/flavrjosh/uXzTV/
这是我正在尝试调试的一个更大问题的一部分,其中 IE9 在页面刷新后没有触发事件(第一次工作,但在刷新时 - F5 或刷新按钮没有任何反应)。
任何帮助/建议将不胜感激
【问题讨论】:
-
只是想知道你为什么要这样做?
-
基本上 App.run() 将包含检查用户是否登录的逻辑。它在服务承诺对象返回用户信息以验证登录后触发一个事件。其他控制器可以监听登录验证事件并对其采取行动。
-
为什么你没有一个服务来检查这个并在你想要的每个控制器中调用这个服务?无论如何,这两种方式都需要在控制器中添加一些代码。
-
这是一个简单的例子。完整版使用带有 defer 模块的服务来提供一个 Promise 对象,该对象在成功响应时触发事件。这有同样的结果。我最终只使用了 $scope.$watch() 来处理 promise 回调更改值的时间。
-
是的,听起来更好。因为我觉得你使用 run 的方式有点不像它的设计方式。
标签: javascript angularjs