私は簡単なリアルタイムビジターカウンタを作った。socket.io:切断イベントが発生しない
this repositoryからダウンロードできます。
何が起きるかは、サーバー上の切断イベント(ブラウザーを閉じた後でも)が一度も実行されないことです。
server.jsは次のとおりです。クライアント上
(function() {
var app, count, express, io;
express = require('express');
io = require('socket.io');
app = module.exports = express.createServer();
app.configure(function() {
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(require('stylus').middleware({
src: __dirname + '/public'
}));
app.use(app.router);
return app.use(express.static(__dirname + '/public'));
});
app.configure('development', function() {
return app.use(express.errorHandler({
dumpExceptions: true,
showStack: true
}));
});
app.configure('production', function() {
return app.use(express.errorHandler());
});
io = require('socket.io').listen(app);
count = 0;
io.sockets.on('connection', function (socket) {
count++;
io.sockets.emit('count', {
number: count
});
});
io.sockets.on('disconnect', function() {
console.log('DISCONNESSO!!! ');
count--;
io.sockets.emit('count', {
number: count
});
});
app.get('/', function (req, res) {
return res.render('index', {
title: 'node.js express socket.io counter'
});
});
if (!module.parent) {
app.listen(10927);
console.log("Express server listening on port %d", app.address().port);
}
}).call(this);
スクリプトです:
script(type='text/javascript')
var socket = io.connect();
socket.on('count', function (data) {
$('#count').html(data.number);
});
上記のsocket.onは書かれていますか? – swiecki
パーフェクト、今は正常に動作します –
FYI、xhr-pollingがトランスポートに使用されている場合、切断前にかなりの遅延が発生する可能性があります。 –