从函数返回mongojs查询结果

时间:2012-04-23 23:23:39

标签: node.js mongodb express pug

我使用下面的函数从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;})

2 个答案:

答案 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}