7

このエラーに2時間貼り付けて苦労していました..

TypeError: $.connection is undefined
[Break On This Error]   

var chatHubClient = $.connection.chatHub;

これが私のChat.csです(コントローラーフォルダーにあります-これは私が間違っていることだと思いますが、どこに置くか、またはどのようにルーティングするかに関するドキュメントが見つかりません)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using SignalR.Hubs;

namespace SingalrTest.Controllers
{
    public class Chat
    {
        private readonly static Lazy<Chat> _instance = new Lazy<Chat>(() => new Chat());

        public static Chat Instance
        { get { return _instance.Value; } }
    }

    [HubName("chatHub")]
    public class ChatHub : Hub
    {
        private readonly int TimeoutInSeconds = 30;
        private readonly Chat _chat;

        public ChatHub() : this(Chat.Instance) { }

        private ChatHub(Chat chat)
        {
            this._chat = chat;
        }

        public void Join(string channelName)
        {
            System.Diagnostics.Debug.WriteLine("Someone joined " + channelName);
        }
    }
}

そして最後に、_Layout.cs.html

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8" />
        <title>@ViewBag.Title - My ASP.NET MVC Application</title>
        <link href="~/favicon.ico" rel="shortcut icon" type="image/x-icon" />
        <meta name="viewport" content="width=device-width" />

        @Styles.Render("~/Content/css")
        @Scripts.Render("~/bundles/modernizr")
        @Scripts.Render("~/Scripts/jquery-1.8.1.js")
        @Scripts.Render("~/Scripts/jquery.signalR-0.5.3.js")
        @Scripts.Render("~/signalr/hubs")

        <script type="text/javascript">
            $(document).ready(function () {
                // var chatHubClient = jQuery.connection.chatHub;
                var chatHubClient = $.connection.chatHub;

                $.connection.chatHub.start(function () {
                    chatHubClient.join('TEST');
                });
            });
        </script>
    </head>
    <body>
    ...
    </body>
</html>

/signalr/hubs にアクセスすると、ソースが正しく生成されていることがわかります。それで、私は何が欠けているのですか?

4

2 に答える 2

8

あなたは先に進んだかもしれません...

しかし、ここに解決策があります。

head タグ内にすべてのスクリプトを正しい順序で配置します。ただし、_Layout.cshtmlVisual Studio テンプレートの body タグの末尾に次の行があります。

@Scripts.Render("~/bundles/jquery")
@RenderSection("scripts", required: false)

このバンドルには、ロード時に $ オブジェクトを上書きする jQuery ライブラリが含まれています。したがって、SignalR によるこのセットアップの「もの」は上書きされ、アクセスできなくなります。

ページで以下を使用するだけです。

@section scripts {
    @* Load your scripts here. (and remove jQuery, coz it's already loaded) *@
}

お役に立てれば。

于 2013-02-19T10:01:33.040 に答える
0

thisによると、バージョン 0.5.3 では、接続構文を変更する必要があります。

var connection = $.hubConnection();

またはトラフィックをセカンダリ サーバーに転送する

var connection = $.hubConnection("http://localhost:58416/");

ハブに接続:

var hub = connection.createProxy('your_hub_name');

また、メッセージの送受信時の変更もいくつかあります

この助けを願っています

于 2012-09-24T11:09:51.087 に答える