Súper clásico error de principiante sobre el asincronismo :)
¿Qué está pasando?:
var name; // FIRST you declare the name variable
schema.findone({name : 'Bob'} , function(er , db){ // SECOND you launch a request to the DB
name = db; // FOURTH name is populated.
console.log(db);
});
console.log(name); // !! THIRD !! you log name - it's empty
Lo que debes hacer:
schema.findone({name : 'Bob'} , function(er , db){
doSomethingElse(db);
});
function doSomethingElse(name){
console.log(name); // It's defined.
}
Ni siquiera debería declarar una variable global, ya que es una mala práctica. Tan pronto como los datos estén disponibles, páselos a otra función y haga algo con ellos. Para que no contamines tu alcance global.
Editar :Ya que absolutamente quiere una variable global por alguna razón, entonces haga esto:
var name;
schema.findone({name : 'Bob'} , function(er , db){
name = db;
console.log(name); // works fine
doSomethingElse();
});
console.log(name); // name is empty here, because the DB request is still in progress at this stage
function doSomethingElse(){
console.log(name); // Tadaaaa! It's a global variable and is defined!
}