Angular 信号员:如何不经过重新连接过程直接停止/关闭一个连接
在我的Angular项目中,我使用信号器获取实时数据,如下所示:Angular 信号员:如何不经过重新连接过程直接停止/关闭一个连接,angular,signalr,Angular,Signalr,在我的Angular项目中,我使用信号器获取实时数据,如下所示: var connection = $.hubConnection(); var contosoChatHubProxy = connection.createHubProxy('contosoChatHub'); contosoChatHubProxy.on('addContosoChatMessageToPage', function(userName, message) { console.log(userName +
var connection = $.hubConnection();
var contosoChatHubProxy = connection.createHubProxy('contosoChatHub');
contosoChatHubProxy.on('addContosoChatMessageToPage', function(userName, message) {
console.log(userName + ' ' + message);
});
connection.start()
.done(function(){ console.log('Now connected, connection ID=' + connection.id); })
.fail(function(){ console.log('Could not connect'); });
connection.stateChanged((state: SignalR.StateChanged) => {
if (state.newState === ConnectionState.Disconnected) {
connection.start()
}
});
以上代码与我的代码不完全相同。但逻辑是相同的,启动连接,并设置重新连接逻辑在我的项目中,基于某些情况,我需要重置连接,这意味着我需要关闭现有连接并启动一个新连接
我尝试了
connection.stop()
,但由于此处存在重新连接逻辑,连接将首先变为断开连接状态并自动重新启动信号器客户端是否有其他API可以满足我的要求 为调用
connection.stop()
时设置一个标志
我们称之为手动停止
并在您的stateChanged
处理程序中添加手动停止的检查
无论在何处调用connection.stop()
,请执行以下操作:
fucntion_to_close_connection(){
manually_stopped = 1
connection.stop()
}
connection.stateChanged((state: SignalR.StateChanged) => {
if (state.newState === ConnectionState.Disconnected && manually_stopped == 0) {
connection.start()
}
});