服务器端server.js代码
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代码
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的同一端.
这样:
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行代码:是我们新添加的.
事实证明不可以,不会有任何的打印.但是也是不会报错的.
emit的执行,美其名曰:发送事件.如果有参数,美其名曰:携带参数.