Skip to content

Instantly share code, notes, and snippets.

@baniol
Last active August 29, 2015 14:06
Show Gist options
  • Save baniol/d495257e82872bb12fd3 to your computer and use it in GitHub Desktop.
Save baniol/d495257e82872bb12fd3 to your computer and use it in GitHub Desktop.
<!doctype html>
<html>
<head>
<script src='//code.jquery.com/jquery-1.7.2.min.js'></script>
<!-- <script src='//localhost:3000/socket.io/socket.io.js'></script> -->
<script src='//baniowski.net:3000/socket.io/socket.io.js'></script>
<script>
// var socket = io.connect('//localhost:3000');
var socket = io.connect('//baniowski.net:3000');
socket.on('welcome', function(data) {
$('#messages').append('<li>' + data.message + '</li>');
socket.emit('i am client', {data: 'foo!'});
});
socket.on('time', function(data) {
console.log(data);
$('#messages').append('<li>' + data.time + '</li>');
});
socket.on('error', function() { console.error(arguments) });
socket.on('message', function() { console.log(arguments) });
</script>
</head>
<body>
<ul id='messages'></ul>
</body>
</html>
var http = require('http'),
fs = require('fs'),
// NEVER use a Sync function except at start-up!
index = fs.readFileSync(__dirname + '/index.html');
// Send index.html to all requests
var app = http.createServer(function(req, res) {
res.writeHead(200, {'Content-Type': 'text/html'});
res.end(index);
});
// Socket.io server listens to our app
var io = require('socket.io').listen(app);
// Send current time to all connected clients
function sendTime() {
io.sockets.emit('time', { time: new Date().toJSON() });
}
// Send current time every 10 secs
setInterval(sendTime, 10000);
// Emit welcome message on connection
io.sockets.on('connection', function(socket) {
socket.emit('welcome', { message: 'Welcome!' });
socket.on('i am client', console.log);
});
app.listen(3000);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment