我已经在strophe.js上开发了一个基本的XMPP客户端。
登录时,我创建了一些处理程序,例如:
connect = new Strophe.Connection('http://localhost/http-bind');
...
...
connect.addHandler(on_message, null, "message", "chat");
connect.addHandler(on_presence, null, "presence");
...
...
然后我“听取”它们的信息
function on_presence(presence) {
// handling presence
}
function on_message(presence) {
// handling presence
}
我正在尝试将它转换为AngularJS。第一部分相当简单。我有一个控制器,可以很好地处理登录部分:
angular.module('app').controller('loginCtrl', function($scope) {
connect = new Strophe.Connection('http://website.com/http-bind');
connect.connect(data.jid, data.password, function (status) {
if (status === Strophe.Status.CONNECTED) {
connect.addHandler(on_message, null, "message", "chat");
connect.addHandler(on_presence, null, "presence");
}
}
})
但是,在所有我拥有的控制器中,我如何开始在Angular的上下文中侦听那些事件(on_message,on_presence)。
你需要在所有控制器中注入相同的实例,并使用该实例注册监听器,以确保在整个应用程序中处理所有事件。