Javascript Websocket неожиданно закрывается, когда скрипт загружается извне - PullRequest
0 голосов
/ 05 июля 2018

При создании приложения чата в Django я использовал встроенный javascript, и он работал. Но если я напишу тот же код во внешнем JavaScript, WebSocket закроется. Я проверил все ссылки и статический путь к файлу. Сценарий загружен полностью, но WebSockets закрывается после их открытия.

Вот руководство с официального сайта Django Channels , и этот javascript работает только во встроенном виде, а не во внешнем скрипте.

И, вот мой репозиторий Github , где я реализовал Websockets. Как я могу написать код JS во внешнем скрипте вместо встроенного? Я гуглил, но не нашел помощи, и даже на этот вопрос еще не ответили.

Вот код, о котором я говорю, и веб-сокеты не будут работать, если определены внешне:

<!-- chat/templates/chat/room.html -->
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8"/>
    <title>Chat Room</title>
</head>
<body>
    <textarea id="chat-log" cols="100" rows="20"></textarea><br/>
    <input id="chat-message-input" type="text" size="100"/><br/>
    <input id="chat-message-submit" type="button" value="Send"/>
</body>
<script>
    var roomName = {{ room_name_json }};

    var chatSocket = new WebSocket(
        'ws://' + window.location.host +
        '/ws/chat/' + roomName + '/');

    chatSocket.onmessage = function(e) {
        var data = JSON.parse(e.data);
        var message = data['message'];
        document.querySelector('#chat-log').value += (message + '\n');
    };

    chatSocket.onclose = function(e) {
        console.error('Chat socket closed unexpectedly');
    };

    document.querySelector('#chat-message-input').focus();
    document.querySelector('#chat-message-input').onkeyup = function(e) {
        if (e.keyCode === 13) {  // enter, return
            document.querySelector('#chat-message-submit').click();
        }
    };

    document.querySelector('#chat-message-submit').onclick = function(e) {
        var messageInputDom = document.querySelector('#chat-message-input');
        var message = messageInputDom.value;
        chatSocket.send(JSON.stringify({
            'message': message
        }));

        messageInputDom.value = '';
    };
</script>
</html>
...