服務器端server.js代碼html
1 var express=require("express"); 2 var http=require("http"); 3 var sio=require("socket.io"); 4 var app=express(); 5 var server=http.createServer(app); 6 var fs=require("fs"); 7 app.get("/", function (req,res) { 8 res.sendfile(__dirname+"/index.html"); 9 }); 10 server.listen(1337); 11 var socket=sio.listen(server); 12 socket.on("connection", function (socket) { 13 socket.emit("news",{hello:"你好"}); 14 socket.on("otherEvent", function (data) { 15 console.log("服務器端接受到數據:%j",data); 16 }) 17 });
客戶端index.html代碼express
1 <!DOCTYPE html> 2 <html> 3 <head lang="en"> 4 <meta charset="UTF-8"> 5 <title></title> 6 <script src="/socket.io/socket.io.js"></script> 7 <script> 8 var socket=io.connect(); 9 socket.on("news", function (data) { 10 console.log(data.hello); 11 socket.emit("otherEvent",{my:"data"}); 12 }); 13 </script> 14 </head> 15 <body> 16 17 </body> 18 </html>
突然想到一個問題.我可不能夠把news的監聽代碼寫到和emit的同一端.服務器
這樣:app
1 var express=require("express"); 2 var http=require("http"); 3 var sio=require("socket.io"); 4 var app=express(); 5 var server=http.createServer(app); 6 app.get("/", function (req,res) { 7 res.sendfile(__dirname+"/index.html"); 8 }); 9 server.listen(1337,"127.0.0.1", function () { 10 console.log("開始監聽1337"); 11 }); 12 var socket=sio.listen(server); 13 14 socket.on("connection", function (socket) { 15 socket.on("news", function (data) { 16 console.log(data.hello); 17 }); 18 socket.emit("news",{hello:"你好"}); 19 });
注意15~17行代碼:是咱們新添加的.socket
事實證實不能夠,不會有任何的打印.可是也是不會報錯的.ui
emit的執行,美其名曰:發送事件.若是有參數,美其名曰:攜帶參數.socket.io