我使用下面的函数从ids中获取用户名。它运作不佳。 我可以写console.log(result.first_name);在查询功能中,用户名显示在我的终端中,但不显示在浏览器中。我尝试在函数的末尾添加“return'something';”,看看它是否出现在浏览器中 - 它确实如此。如何编写函数以便返回查询结果?
函数(app.js中的全局函数)
function usernameFromId(id, callback){
db.users.findOne({ _id: ObjectId(id.toString()) }, function(err, result) {
var first_name = result.first_name;
console.log(first_name); // names show up in the console…
callback(first_name);
});
};
页面处理程序(在app.js中)
app.get('/books', function(req, res){
function timeSince(dato){
moment.lang('nb');
return moment(dato).fromNow();
};
db.books.find().sort({ added:-1 }, function(err, docs) {
var books = docs;
db.activity.find().limit(9).sort({ time:-1 }, function(err, docs) {
var activity = docs;
res.render('books', {
books: books,
activity: activity,
timeSince: timeSince,
usernameFromId: usernameFromId
})
});
});
});
模板(books.jade)
- each a in activity
p=usernameFromId(a.user_id, function(name){return name;})
答案 0 :(得分:2)
否,因为JavaScript的异步性质。我在您的代码中添加了一些注释,以指示实际的执行顺序。这就是你收到错误的原因。
function usernameFromId(id){
var id = id.toString(); // 1
db.users.findOne({ _id: ObjectId(id) }, function(err, result) {
var first_name = result.first_name; // 3
});
return first_name; // 2
};
编辑:你可能想要类似下面的内容
function usernameFromId(id, callback){
var id = id.toString();
db.users.findOne({ _id: ObjectId(id) }, function(err, result) {
var first_name = result.first_name;
callback(first_name);
});
};
答案 1 :(得分:-1)
好的,我找到了解决方案。不确定它是否有用,但它确实有效。不需要功能。
页面处理程序(在app.js中):
app.get('/books', function(req, res){
db.activity.find().limit(9).sort({ time:-1 }, function(err, docs) {
var activity = docs;
db.users.find(function(err, docs) {
var users = docs;
res.render('books', {
page_title:'books',
activity: activity,
users: users
})
});
});
});
模板(books.jade):
- each a in activity
- for u in users
- if (a.user_id == u._id.toString())
| #{u.first_name}