2014-02-10 48 views
0

我想了解为什么我的indexOf不工作!实际上,每当用户加载网站的页面时,服务器都会收到包含一个(就目前而言)值的变量“data”:用户的名称。NodeJS Socket.IO:indexOf不工作

client.js:

$.ajax({ 
    type: "POST", 
    url: "ajax.php", 
    data: { 
     ajaxRequest: "userInfos" 
    }, 
    success: function(data){ 
     var data = JSON.parse(data); 
     var userInfos = { 
      name: data.username, 
     } 
     socket.emit('pong',JSON.stringify(userInfos)); 
    } 
}); 

server.js:

client.on('pong',function(data){ 
     var data = JSON.parse(data); 
     if(data.name != null) { // On s'assure qu'il est connecté 
      /** VARIABLES SESSION **/ 
      client.set("name",data.name); 
      client.set("id",client.id); 
      /** VARIABLES SESSION **/ 
      if(connected.indexOf(data.name) == -1){ // Si il n'est pas dans le tableau 
       var usersInfos = { 
        name: data.name, 
        id: client.id 
       }; 

       io.sockets.emit('pong',JSON.stringify(usersInfos)); 
       connected.push(JSON.stringify(usersInfos)); // On remet son pseudo 
       console.log("[PONG] "+data.name+" ("+client.id+") est connecté"); 
      } 
     } 
    }); 

因此,如果用户尚未在对象存在的,但实际上,不工作usersInfos将只完成...他在每次页面加载或刷新后都推送用户...

以下是连接方式和usersInfos的声明:

var connected = []; 
var usersInfos = {}; 

请帮帮我,我会杀了人!

回答

0
connected.push(JSON.stringify(usersInfos)) 
… 
connected.indexOf(data.name) == -1 

如果你的connected阵列上推JSON字符串,你将不能够找到的唯一.name在那里。希望能够挽救生命:-)

+0

对不起慢!我不明白......实际上,数据被解析为“var data = JSON.parse(data)”,所以在“connected.indexOf(data.name)”“connected”被解析并且“data”也被解析! –

+0

是的,'data'是一个解析对象,但是'JSON.stringify(usersInfos)'显然不是。 – Bergi

0

我通过编写多维对象函数解决了我的问题!

下面是函数:

/** 
* Création d'un tableau d'objets multidimensionnel 
*/ 
function mdimAdd(arrayName,values) { 
    // On vérifie si l'array est déjà un objet ou non. 
    if(typeof(arrayName) == "object") { 
     arrayName = JSON.stringify(arrayName); // Si oui, on la transforme en string 
    } 

    arrayName = arrayName.slice(0,-1); // On supprime le dernier caractère 
    if(S(arrayName).endsWith("}")) { 
     arrayName = arrayName+","; 
    } 

    arrayName = arrayName+""+values; // On rajoute les valeures 
    arrayName = arrayName+"}"; // On ferme l'objet 

    return JSON.parse(arrayName); // On retourne le tableau sous forme d'objet JSON 
} 

这里是创建多维对象行:

usersInfos = mdimAdd(usersInfos,'"'+data.name+'": {"name": "'+data.name+'","id": "'+client.id+'"}'); 

然后现在我做到这一点:

client.on('pong',function(data){ 
     data = JSON.parse(data); 
     if(data.name != null) { // On s'assure qu'il est connecté 
      /** VARIABLES SESSION **/ 
      client.set("name",data.name); 
      client.set("id",client.id); 
      /** VARIABLES SESSION **/ 

      if(!usersInfos[data.name]){ // Si il n'est pas dans le tableau 
       usersInfos = mdimAdd(usersInfos,'"'+data.name+'": {"name": "'+data.name+'","id": "'+client.id+'"}'); 
       console.log("[PONG] "+data.name+" ("+client.id+") est connecté"); 
      } 
     } 
    });