我已经有一个与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之前,此页面稍微延迟不是问题.