天天看点

【转】你知道socket.io中connect事件和connection事件的区别吗?基本情形交换位置:connect套connection交换位置:connection套connect结论

server端的

socket.io

中有两个连接事件.一个是

.on('connect')

,一个是

.on('connect')

.

官网上没有对这两个事件的区别进行解释.

那么这两个事件有什么区别呢? 使用起来似乎没有什么差别哎?

笔者就2.0.4版本的

socket.io

进行实验.

基本情形

这段代码搭建起了一个最简单的socket.io服务器,监听1111端口.

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);

io.on('connect',function (socket) {
    console.log('conenct',socket.id);
});

io.on('connection', function(socket){
    console.log('connection',socket.id);
});

http.listen(1111);                

客户端连接之后,log如下:

conenct 8uBVxwqym7pxsJANAAAA
connection 8uBVxwqym7pxsJANAAAA           

可以看到,都正常地响应了连接事件.但是,我们发现

connect

事件似乎要先于

connection

事件,因为它的日志在前!

我们验证一下我们的猜想.

交换位置:connect套connection

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);

io.on('connect',function (socket) {
    console.log('conenct',socket.id);
    io.on('connection', function(socket){
        console.log('connection',socket.id);
    });
});

http.listen(1111);                

我们发现,输出log的顺序没有变化:

conenct pSlSKNaabR2LBCujAAAA
connection pSlSKNaabR2LBCujAAAA           

这说明,connection事件在connect事件之后还能被触发.

交换位置:connection套connect

我们想要验证connection事件之后,connect不能被触发.

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);


io.on('connection', function(socket){
    console.log('connection',socket.id);
    io.on('connect',function (socket) {
        console.log('conenct',socket.id);
    });
});

http.listen(1111);                

输出结果和预期相符,我们可以发现,connection事件触发之后,connect事件没有被触发!

connection 1QCOp0Y0fuH2xG-LAAAA           

结论

connect

connection

事件功能相似,但是被触发的时间不同.

connect

先于

connetion

.

connect

是一旦有连接就被触发,而

connection

在连接完全建立后才被触发.

一般直接如同官网示例那样,直接使用

connection

事件即可.

但是为了保持与前端的一致性,全部使用

connect

事件也未尝不可.

参考资料:

https://socket.io/get-started...

https://stackoverflow.com/que...

继续阅读