Untuk menavigasi async js, saya melakukan beberapa ke sana kemari memancarkan dengan socket.io dan berhasil
di sisi server
var query = records.find({$or:[{starter:data},{receiver:data}]},{});//check the records table for all persons the logged in user has spoken to
query.sort('-createDate').exec(function (err, docs){
if(err) throw err;
for(var i=docs.length-1; i>= 0; i--)
{
var starter = docs[i].starter;
var receiver = docs[i].receiver;
var lasttxt = docs[i].lastMessage;
if (starter == socket.usernames){
var target = receiver;
}else
{
var target = starter;
}
var userlast = target+" "+lasttxt;
socket.emit('lastly', userlast);//Emit the username and last message for the client to emit back here
}
})
Di sisi klien Anda, Ambil data yang dipancarkan
socket.on('lastly', function(data){//Recieve the data and send right back
socket.emit('lastly2', data);
});
Kembali ke sisi server Anda, ambil data yang dikirim kembali
socket.on('lastly2', function(data){//receive the username and last message to work with
var check = data;
var space = check.indexOf(' ');
var name = check.substr(0, space);
var msg = check.substr(space+1);
usersrec.find({username:name},{}).lean().exec(function (errx, docx){
if(errx) throw errx;
docx[0].message = msg;
socket.emit('usernames', docx);
});
Ya itu mungkin tidak lazim, tapi setidaknya itu menyelesaikan pekerjaan. Saya terbuka untuk saran yang lebih baik