我想了解为什么我的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 = {};
请帮帮我,我会杀了人!
对不起慢!我不明白......实际上,数据被解析为“var data = JSON.parse(data)”,所以在“connected.indexOf(data.name)”“connected”被解析并且“data”也被解析! –
是的,'data'是一个解析对象,但是'JSON.stringify(usersInfos)'显然不是。 – Bergi