Super klasyczny błąd początkującego dotyczący asynchroniczności :)
Co się dzieje :
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
Co powinieneś zrobić :
schema.findone({name : 'Bob'} , function(er , db){
doSomethingElse(db);
});
function doSomethingElse(name){
console.log(name); // It's defined.
}
Nawet nie zadeklarowałeś zmiennej globalnej, ponieważ jest to zła praktyka. Jak tylko dane będą dostępne, przekaż je do innej funkcji i zrób coś z nimi. Więc nie zanieczyszczasz swojego globalnego zasięgu.
Edytuj :Ponieważ z jakiegoś powodu absolutnie potrzebujesz zmiennej globalnej, zrób to :
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!
}