Socket.io:“无法读取未定义的属性'emit'”

时间:2016-06-09 12:24:33

标签: javascript jquery node.js sockets socket.io

所以我目前正在使用socket.io开发我的网站。

今天,当我实现套接字时,我得到了一个很好的小错误“无法读取未定义的属性'emit'” 我找不到我的代码中的错误,所以我希望你们能帮助我。

App.js:

var socket  = require( 'socket.io' );
var express = require('express');
var app     = express();
var server  = require('http').createServer(app);
var io      = socket.listen( server );
var port    = 9999;

server.listen(port, function () {
  console.log('Listening at port %d', port);
});

io.sockets.on('connection', function (socket) {
    console.log('User connected');

    socket.on('create_socket', function(port){
    console.log(port);
});

客户端:

<div>
    <p class="connected" hidden>Connected port : 9999</p>
    <p class="connect_error" hidden><strong>Can not connect to socket on port 9999</strong></p>
</div>

<script>
    var socket = io.connect("http://localhost:9999");

    // If connection can not be established
    socket.on('connect_error', function(socket) {
        $('.connected').hide();
        $('.connect_error').show();
    });

    // Connection established
    socket.on('connect', function(socket) {
        $('.connect_error').hide();
        $('.connected').show();
       // socket.on('create_socket', null, <?= $port; ?> );
       socket.emit('create_socket', '<?= $port; ?>');
    });
</script>

顺便说一句,所有socket.io/jquery / ...包含都正确完成,即使它们没有出现在代码上

提前致谢

1 个答案:

答案 0 :(得分:6)

客户代码:

更改

// Connection established
    socket.on('connect', function(socket) {

// Connection established
    socket.on('connect', function(data) {

最后:

// Connection established
    socket.on('connect', function(data) {
        $('.connect_error').hide();
        $('.connected').show();
       console.log(data);
       socket.emit('create_socket', '<?= $port; ?>');
    });

以前,你在那里覆盖套接字对象。