這篇文章主要介紹了node中使用socket.io製作命名空間,需要的朋友可以參考下。
如果開發者想在一個特定的應用程式中完全控制訊息與事件的發送,只需要使用一個預設的"/"命名空間就足夠了.但是如果開發者需要將應用程式作為第三方服務提供給其他應用程式,則需要為一個用於與客戶端連接的socket連接埠定義一個獨立的命名空間.
製作兩個命名空間
chat和news然後在客戶端相互發送訊息。
var express=require("express"); var http=require("http"); var sio=require("socket.io"); var app=express(); var server=http.createServer(app); app.get("/", function (req,res) { res.sendfile(__dirname+"/index.html"); }); server.listen(1337,"127.0.0.1", function () { console.log("开始监听1337"); }); var io=sio.listen(server); var chart=io.of("/chat").on("connection", function (socket) { socket.send("欢迎访问chat空间!"); socket.on("message", function (msg) { console.log("chat命名空间接收到信息:"+msg); }); }); var news=io.of("/news").on("connection", function (socket) { socket.emit("send message","欢迎访问news空间!"); socket.on("send message", function (data) { console.log("news命名空间接受到send message事件,数据为:"+data); }); });
HTML程式碼:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="/socket.io/socket.io.js"></script> <script> var chat=io.connect("http://localhost/chat"), news=io.connect("http://localhost/news"); chat.on("connect", function () { chat.send("你好."); chat.on("message", function (msg) { console.log("从char空间接收到消息:"+msg); }); }); news.on("connect", function () { news.emit("send message","hello"); news.on("send message", function (data) { console.log("从news命名空间接收到send message事件,数据位:"+data); }); }); </script> </head> <body> </body> </html>
運行結果:
小夥伴們是否了解了node.js使用socket.io製作命名空間的方法了呢,這裡的2個例子很簡單,童鞋們自由發揮下。
相關建議: