类库中的SignalR hub类

时间:2013-12-27 06:30:28

标签: c# javascript signalr signalr-hub signalr.client

我在类库中有一个信号器hubclass

当我在我的web应用程序中使用该hubclass时,使用下面的javascript代码引用该类库,它不起作用,

$(function () {

    var chat = $.connection.notificationHub;

    chat.client.newMessage = function (message) {
        alert(message);

        $('#messages').append('<li><strong>' +  message + '</strong>: </li>');
    };
    $.connection.hub.start();
});

1 个答案:

答案 0 :(得分:2)

您需要一个事件来触发Hub类中的方法。见下面的例子:

类库中的NotificationHub

public class NotificationHub : Hub
{
    public void Send(string message)
    {
        Clients.All.newMessage(message);
    }
}

网络应用

<input type="text" id="message" />
<input type="button" id="sendmessage" value="Send" />
<ul id="messages"></ul>

   <script src="~/Scripts/jquery-1.10.2.min.js"></script>
   <script src="~/Scripts/jquery.signalR-2.0.1.min.js"></script>
   <script src="signalr/hubs"></script>

    <script>
        $(function () {
            var chat = $.connection.notificationHub;
            chat.client.newMessage = function (data) {
                //alert(data);
                $('#messages').append('<li><strong>' + data + '</strong>: </li>');
            };
            $('#message').focus();
            $.connection.hub.start().done(function () {
                console.log("Connected");
                $('#sendmessage').click(function () {
                    chat.server.send($('#message').val());
                    $('#message').val('').focus();
                });
            });
        });
    </script>

注意

因为hubclass在类库中,所以需要在其中安装Microsoft ASP.NET SignalR包。您还需要在Web应用程序中安装它。然后添加hubclass引用到webapplication。在您的Startup类中添加app.MapSignalR(),如下所示:

public partial class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            ConfigureAuth(app);
            app.MapSignalR();
        }
    }