首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >处理浏览器重新加载socket.io

处理浏览器重新加载socket.io
EN

Stack Overflow用户
提问于 2013-11-28 15:30:35
回答 1查看 25.5K关注 0票数 22

在socket.io中有一种方法可以在disconnected事件中创建超时,然后检查用户是否已重新连接?

其思想是仅当用户在超时后未重新连接时才发送数据/将用户状态保存在数据库中

编辑:关注@Are Wojciechowski回答,我完成了一个多标签& F5泛洪处理程序

https://gist.github.com/foohey/7696811

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-11-28 16:34:30

有一个socket.on('disconnect', function () { ... });。所以你可以这样做

代码语言:javascript
复制
socket.on('disconnect', function () {
    setTimeout(function () {
         //do something
    }, 10000);
});

编辑1:

我现在明白了。所以也许你应该这样做:

客户端:

代码语言:javascript
复制
//right after connection
socket.emit('register', localstorage.getItem('gameUniqueId'));

//somewhere, when game starts
var randomlyGeneratedUID = Math.random().toString(36).substring(3,16) + +new Date;
localStorage.setItem('gameUniqueId', randomlyGeneratedUID);

服务器:

代码语言:javascript
复制
io.sockets.on('connection', function (socket) {
    var player = null;

    socket.on('register', function (data) {
        if (data !== null) {
            //there was something in localstorage
            if (game.Players.existsUID(data)) {
                player = game.Players.getByUID(data);
                player.disconnected = false;
            } else {
                //timed out, create new player
            }
        } else {
            //localStorage is not set, create new player
        }
    });

    socket.on('disconnect', function () {
        player.disconnected = true;
        setTimeout(function () {
            if (player.disconnected) player.delete();
        }, 10000);
    });
});
票数 32
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20260170

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档