admin管理员组文章数量:1401669
I have a problem getting the restaurantname from the db with node.js, it seems it has to do something with callback parameters but I can’t find the solution for my case, hopefully one of you can help me .
I have made function who gets the name of the restaurant from a database. The first console log line gives the right retvalue and the second one gives undefined, how can I write the code so that the return value is the name of the restaurant?
Kind regards, Robert
function restaurantName(id) {
var retvalue;
try {
F.model('restaurant').load(id).then(function (restaurant) {
retvalue = restaurant.Name;
console.log('restaurantName 1(' + id + ')' + retvalue);
})
} catch (err) {
retvalue = 'Error';
}
console.log('restaurantName 2(' + id + ')' + retvalue);
return retvalue;
};
I have a problem getting the restaurantname from the db with node.js, it seems it has to do something with callback parameters but I can’t find the solution for my case, hopefully one of you can help me .
I have made function who gets the name of the restaurant from a database. The first console log line gives the right retvalue and the second one gives undefined, how can I write the code so that the return value is the name of the restaurant?
Kind regards, Robert
function restaurantName(id) {
var retvalue;
try {
F.model('restaurant').load(id).then(function (restaurant) {
retvalue = restaurant.Name;
console.log('restaurantName 1(' + id + ')' + retvalue);
})
} catch (err) {
retvalue = 'Error';
}
console.log('restaurantName 2(' + id + ')' + retvalue);
return retvalue;
};
Share
Improve this question
edited Feb 16, 2017 at 21:57
piotrbienias
7,4111 gold badge30 silver badges33 bronze badges
asked Feb 16, 2017 at 15:12
user3493979user3493979
331 silver badge4 bronze badges
3
-
Can't you keep the second
console.log
inside thetry
block? – David R Commented Feb 16, 2017 at 15:27 - You're not handling any error case in your callback function. – Matt D. Webb Commented Feb 16, 2017 at 15:32
- 3 Possible duplicate of How do I return the response from an asynchronous call? – Ben Fortune Commented Feb 16, 2017 at 15:45
1 Answer
Reset to default 6Your function getting data from database is asynchronous, so the second console.log
as well as return
statement are done before the database operation finishes executing. You should return the value inside .then()
function restaurantName(id) {
var retvalue;
return F.model('restaurant').load(id).then(function (restaurant) {
retvalue = restaurant.Name;
console.log('restaurantName 1(' + id + ')' + retvalue);
return retvalue;
}).catch(function(error){
return 'Error';
});
};
And this function will also return a promise
, so you would have to call it like that
restaurantName(1).then(function(result){
console.log(result); // result would be retValue or 'Error'
});
EDIT
Your second problem, mentioned in a ment below this answer, is also concerned with how the promises work. In this case I remend you use Promise.all
method which resolves when all of the promises passed as an argument will resolve
let promises = [];
snapshot.forEach(u => {
let item = u.val();
item.key = u.key;
promises.push(restaurantName(item.restaurant).then(function(result){
item.restaurantName = result;
return item;
}));
});
Promise.all(promises).then(result => {
console.log(result); // here you get array of items
});
What happens here is you create an array of promises that resolve with given value (which in this case is item
object every time). When you pass this array to Promise.all
method, it resolves to array of values that every single promise resolved to (if no error occurs of course)
本文标签: javascriptnodejs functions returns undefined valueStack Overflow
版权声明:本文标题:javascript - node.js functions returns undefined value - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1744318042a2600359.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论