socket.io,命名空間

     原文: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;
};
相關文章
相關標籤/搜索