更新:我进一步简化了错误案例,并在 SignalR 的 GitHub 页面上提出了问题。您可以在此处查看问题:https ://github.com/SignalR/SignalR/issues/1828 。实际上这个错误与 AngularJS 无关。
我有一个在后端使用 ASP.NET 和 SignalR 并在前端使用 AngularJS 的项目。一切正常,除了当我在 AngularJS 中移动并且再次创建控制器时,它们无法替换原始的 SignalR 回调方法。
这是我的控制器的代码:
function SignalRProblemCtrl($scope) {
var bar = $.connection.bar;
$.connection.hub.start();
$scope.currentMessage = "";
$scope.messages = [];
$scope.messages.push("HELLO!");
var date = new Date();
bar.client.addMessage = function (message) {
$scope.$apply(function () {
console.log("Callback set on " + date + ": " + message);
$scope.messages.push(message);
});
};
$scope.send = function () {
bar.server.send($scope.currentMessage, "Extra data");
};
}
SignalRProblemCtrl.$inject = ['$scope'];
在我第一次访问这个控制器时,我可以发送和接收消息,并且我所有的 Angular 绑定都可以正常工作。我的控制台有输出:
Callback set on Fri Apr 05 2013 14:37:13 GMT+0300 (E. Europe Daylight Time): First page load controllers.js:37
这一切都很好,花花公子。移动到另一个页面并再次访问 SignalRProblemCtrl 后会出现问题。这次我可以发送和接收消息,消息被写入控制台但我的绑定不会更新。控制台中的输出指向根本原因:
Callback set on Fri Apr 05 2013 14:37:13 GMT+0300 (E. Europe Daylight Time): Second page load controllers.js:37
所以我的绑定没有得到更新,因为在第二次创建控制器时第一个回调没有被替换。所有 SignalR 消息仍会转到第一个回调,该回调具有控制器前一个实例的 $scope,因此我的视图不会使用最新消息进行更新。
为什么是这样?为什么 SignalR 坚持第一次回调?
PS。我也尝试立即更换回调。使用此代码,可以正确使用最新的回调(带有 date2 的回调)。
var date = new Date();
bar.client.addMessage = function (message) {
$scope.$apply(function () {
console.log("Callback set on " + date + ": " + message);
$scope.messages.push(message);
});
};
var date2 = new Date();
bar.client.addMessage = function (message) {
$scope.$apply(function () {
console.log("Callback set on " + date2 + ": " + message);
$scope.messages.push(message);
});
};