gpt4 book ai didi

javascript - 无法使用 NodeJS/Socket.io 在 HTML 文件中检索简单的广播消息

转载 作者:行者123 更新时间:2023-12-02 14:29:12 25 4
gpt4 key购买 nike

我正在和Socket.io一起学习NodeJS我有一个非常简单的聊天页面。但我不知道我的错误在哪里。

这是我的简单代码:

index.js

var express = require('express');
var app = express();
app.use('/', express.static(__dirname + '/'));
var http = require('http').Server(app);
var io = require('socket.io')(http);

app.get('/', function(req, res){
//res.send('<h1>Hello World</h1>');
res.sendFile(__dirname + '/index.html');
});

io.on('connection', function(socket){
//console.log('a user is connected!');
socket.on('disconnect', function() {
//console.log('user disconnected!');
});
socket.on('chat message', function(msg) {
io.emit('chat message: ' + msg);
});
});

http.listen(3000, function() {
console.log('listening on *:3000');
});

index.html

<body>
<ul id="messages"></ul>
<form action="">
<input id="m" autocomplete="on" /><button>Send</button>
</form>
<script type="text/javascript" src="jquery-1.12.4.js"></script>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io();
$('form').submit(function() {
socket.emit('chat message', $('#m').val());
$('#m').val('');
return false;
});
socket.on('chat message', function(msg) {
console.log(msg); //NO VALUE?
});
</script>
</body>

我无法获取这一行的值:

 socket.on('chat message', function(msg) {
console.log(msg); //NO VALUE?
});

最佳答案

客户端无法接收消息,因为

// Server: Receive and send message
socket.on('chat message', function(msg) {
io.emit('chat message: ' + msg);
}

您发出了一个名为聊天消息:${msg}的事件,但您并未在客户端监听该事件。发出事件时,您可以通过首先定义事件名称,然后将数据指定为 second parameter in JSON format 来执行此操作。 。将上面的代码更改为

// Server: Receive and send message 
socket.on('chat message', function(data) {
io.emit('chat message', { message : data.message });
}

将使用消息作为数据向客户端发出事件。将事件从客户端发送到服务器时,适用相同的语法。所以改变一下

// Client: Send message
$('form').submit(function() {
socket.emit('chat message', $('#m').val());

// Client: send message
$('form').submit(function() {
socket.emit('chat message', {message : $('#m').val()});

当服务器应答您的事件后,您就可以接收并访问消息,如下所示:

// Client: Receive message
socket.on('chat message', function(data) {
console.log(data.message); // VALUE :-)
});

关于javascript - 无法使用 NodeJS/Socket.io 在 HTML 文件中检索简单的广播消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37982058/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com