SignalR在初始加载和更新之间

时间:2015-05-05 20:56:50

标签: javascript c# asp.net-mvc asp.net-web-api signalr

我正在尝试使用signalR构建应用程序。申请大纲将是:

  • 从数据库加载初始状态
  • 订阅成功留言

我一直在寻找一套最佳实践。如果我在初始加载后订阅更新,则存在丢失更新的风险。在初始加载和订阅之间可能会有更新,我会错过更新。

其次,我可以使用某种对象状态id,然后首先订阅更新流,检索数据,然后在对象落后时应用更新。这需要相当多的代码。

有没有最佳做法来处理这个问题?

1 个答案:

答案 0 :(得分:1)

根据您查询更新的时间,可能会遗漏。例如,假设您的后端查询某些通知并将其推送到客户端,然后用户连接(订阅)通知 - 如果在此初始化阶段发送更新并且错过了您推送的原始数据集可能是陈旧的。 / p>

作为最佳做法,我发现废弃发送任何初始数据。相反,请尽快订阅并查询成功连接的更新。例如....

var proxy = $.connection.yourHub;

$.connection.hub.start()
    .done(function () { // <--- immediately call once connected

        // define and call server hub method
        // this will query updates and immediately
        // invoke the associated client function

        proxy.server.queryUpdates();
    })
    .fail(function () {
        console.log('Could not connect!');
    });

proxy.client.serveUpdates = function(updates) {
    // here's your fetched updates on initial connect
}
// YourHub.cs
public void QueryUpdates()
{
    var updates = this.yourService.yourQueryUpdatesmethod();

    Clients.Caller.serveUpdates(updates) // this calls proxy.client.serveUpdates
}

这为您提供了建立连接,监听更新以及在连接时以一次性方式有效提供最新数据集的好处。

注意这不一定是SignalR特定的实现。您可以在此.done()回调中进行典型的ajax调用以检索结果,但我不明白为什么您无法重新使用集线器上已有的所有逻辑。实际上,您可以通过从客户端显式调用它来调用现有的集线器方法。