原文:http://www.cnblogs.com/xiezhengcai/p/3966263.html html
命名空間前端
在api部分咱們說io.connect('ws://103.31.201.154:5555/some')的方式鏈接到命名空間爲some下的socket,在socket.io的前端代碼中,咱們看見,socket.io會將/some下的鏈接存入到一個nsps[nsp]下,須要從新創建一個新的socket鏈接時,除非你配置opts['force new connection']選項,不然socket.io會先尋nsps[nsp]是否已經存在該鏈接,若是存在,直接返回,不存在纔會新建一個,api
Manager.prototype.socket = function(nsp){ //這裏的nsp便是咱們的「/some」 var socket = this.nsps[nsp]; if (!socket) { socket = new Socket(this, nsp); this.nsps[nsp] = socket; var self = this; socket.on('connect', function(){ //重連次數 self.connected++; }); } return socket; };
服務端實現socket
服務端會有 Namespace對象存儲命名空間下的socket,this
function Namespace(server, name){ //命名空間名字「/some」 this.name = name; //sever 實例 this.server = server; //命名空間下的socket this.sockets = []; this.connected = {}; //命名空間中間件,會在socket創建的時候執行,傳入socket實例 this.fns = []; this.ids = 0; this.acks = {}; this.initAdapter(); }
查找room,當須要發送信息的時候socket.io
//查找room,當須要發送信息時 Namespace.prototype.to = Namespace.prototype['in'] = function(name){ this.rooms = this.rooms || []; //不存在則將該命名空間名字push進去 if (!~this.rooms.indexOf(name)) this.rooms.push(name); return this; };