【转】你知道socket.io中connect事件和connection事件的区别吗?

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

结论

connectconnection事件功能相似,但是被触发的时间不同.connect先于connetion.

connect是一旦有连接就被触发,而connection在连接完全建立后才被触发.

一般直接如同官网示例那样,直接使用connection事件即可.

但是为了保持与前端的一致性,全部使用connect事件也未尝不可.

参考资料:
https://socket.io/get-started...
https://stackoverflow.com/que...

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值