sa1*_*125 5 external broadcast angularjs rootscope
我有一个场景,我需要非角度代码(在这种情况下Facebook和Twitter JS sdk)来广播角度控制器可以收听的事件.为什么?在初始页面加载后,我通过AJAX加载和修改页面中的内容.内容有多个喜欢/推特按钮(如博客/聚合器的首页).我想在Facebook"喜欢"按钮或Twitter"分享"按钮上发生点击时添加事件挂钩 - 页面中有一些,每当获取新内容时每个都在变化(再次,通过ajax ).
现在,SDK的处理方式不同:
twttr.events.bind('click', function(event){
// here I'd like to somehow
// $rootScope.$broadcast("twitter:clicked", event.currentTarget)
});
Run Code Online (Sandbox Code Playgroud)
FB.Event.subscribe("edge.create", function(resp) {
// here I'd like to somehow
// $rootScope.$broadcast("facebook:clicked", resp)
});
Run Code Online (Sandbox Code Playgroud)
app.controller("SomeController", ['$scope', function($scope) {
$scope.$on("facebook:clicked", function(event, resp) {
// do something with resp
});
$scope.$on("twitter:clicked", function(event, target) {
// do something target
});
}])
Run Code Online (Sandbox Code Playgroud)
我们的想法是绑定这些事件处理程序,然后处理相关控制器中的广播消息,即使每次获取新内容时都会重新创建这些控制器.
所以基本上,我正在寻找的是一种挂钩现有的已经初始化的角度应用程序$rootScope和$broadcast消息的方法,尽管它不是应用程序的一部分.希望这是有道理的.谢谢.
您可以绑定到Angular代码中的其他应用程序(在最有可能创建链接的指令中).这样你就可以访问了$rootScope.
或者,如果您手动引导应用程序,则可以保留对注入器的引用并获取$rootScope:
var injector = angular.bootstrap(element, ["myAppModule", ...]);
var $rootScope = injector.get("$rootScope");
Run Code Online (Sandbox Code Playgroud)
在任何情况下都不要忘记$apply在外部事件之后打电话.
| 归档时间: |
|
| 查看次数: |
3747 次 |
| 最近记录: |