asp.net – SignalR并不总是准备好后start().done()?

前端之家收集整理的这篇文章主要介绍了asp.net – SignalR并不总是准备好后start().done()?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我已经有一个与SignalR合作的小型项目,但是我的行为却非常不一致.
<script type="text/javascript">
    $(function () {
        var chat = $.connection.brewBattleHub;
        $.connection.hub.start().done(function () {
            $("#broadcast").click(function () {
                // Call the chat method on the server
                chat.server.roll($("#username").val(),$("#drinkname").val());
            });
            chat.server.sendMessage("SignalR loaded...");
        });
    });
</script>

当我加载页面时,有时我看到消息“SignalR加载”,其他时候我不是.

页面上还有一些其他功能,有时这也不起作用.如果我点击按钮,使事情发生得足够,它将最终都会一次性通过…从这一点上,它是金色和完美的.

做start().done()?不能确保它已经准备好了吗?

===
附录,我没有引用jquery手机(谷歌提到有一个错误,当这样做)

解决方法

本周我有一个类似的问题,除了.done()中的代码从未运行过.我启用了日志记录,没有任何记录.检查浏览器的控制台没有错误.查看浏览器的开发工具,我可以看到当我调用start()时,没有网络活动.我确认$.connection.myhubclass返回的代理具有我所有的方法,所以我知道它可以与服务器通话,服务器端代码设置正确.

在一遍又一遍地检查了代码和文档后,我相信我没有做错什么. SignalR是如此简单,如果你遵循这些例子,做错是非常困难的.我在桌子上打了很长时间,试图弄清楚这一点.

然后我注意到,如果我从控制台运行SignalR的启动方法,它将工作.这导致我相信它试图过早地启动连接.我通过从这里更改初始化代码解决我的问题:

$.connection.hub.start().done(function () {
  //Do interesting stuff
});

为此:

setTimeout(function () {
    $.connection.hub.start().done(function () {
      //Do interesting stuff
    });
},5000);

我相信我可以将这个延迟从5秒缩短到更短的时间,但额外的时间似乎是让浏览器准备好创建连接所需要的时间.一旦延迟了,记录开始工作,连接出现,服务器端OnConnected()run和done()在客户端上运行.

在弄清楚这一点之后,我仔细检查了我的JavaScript加载的顺序,也许我正在加载一些不按顺序的顺序,但根据SignalR样本的顺序是正确的.我加载jQuery,SignalR,/ signalr / hubs,然后我的脚本文件,初始化一切.

我可以建议为什么需要延误.我没有看到任何文件,所以我知道这可能是我做的.幸运的是,在启动SignalR之前,此页面稍微延迟不是问题.

猜你在找的asp.Net相关文章