0

在我的自定义模块中,我有这个方法,它将查询数据库并查找用户名是否存在于我的数据库中。我想返回一些值,所以在上层我会知道查询结果。

var findUserbyUsername=function(username)
{
    db.users.find({email:username},function(err,result)
    { 

        if(err|!username) {console.log('username not found'); return 0;} 
        else return 1;
    }
    );
}
module.exports.findUser=findUserbyUsername;

在 app.js 中我会像这样调用上面的方法

var lt=dbutil.findUser('xxxx@gmail.com');

但不幸的是我没有定义....任何人都可以帮我解决这个问题吗?或任何其他建议?

4

3 回答 3

2

您的findUserbyUsername函数不返回任何内容,这就是您得到undefined. 由于 Node 中的数据库操作是异步的,因此无法返回任何有意义的内容并通过回调进行工作。像这样更改您的代码:

var findUserbyUsername = function(username, callback) {
    db.users.find({ email: username }, function(err, result) { 
        if (err || !username) {
            console.log('username not found');
            callback(err? err: 'Username not found');
        } else {
            callback(null, whateverYouWantToReturn);
        }
    });
}
module.exports.findUser = findUserbyUsername;

并像这样使用它:

dbutil.findUser('xxxx@gmail.com', function(err, result) {
    // you have the result from findUserbyUsername() in "result", and "err" is set if there was an error
});

注意:我还修复了您的条件if(err|!username),因为|它是按位运算符,而您实际上需要||逻辑运算符)

err(编辑:在回调中添加了事实上的标准参数)

于 2012-06-07T08:51:48.220 回答
2

这是一个异步代码,当然它不会返回任何东西。您可能需要以下内容:

应用程序.js:

dbutil.findUser( 'xx@gmail.com', function( err, data ) {
    if ( err ) throw err;
    // Handle the datas returned "data"
} );

模块:

var findUserByUserName = function( username, callback ) {
    db.users.find( { email: username }, function( err, result ) {
       if ( err || !username ) {
           console.log( 'username not found' );

           // Call the function passed as parameter
           callback( err ); // You give "undefined" as second parameter
       }
       else {
           callback( err, result ); // You give the datas back
       }
    } );
} );
于 2012-06-07T08:51:57.657 回答
0

问题是您的函数中有一个异步请求,因此 db.users.find 中的返回值在错误的范围内,并且永远不会返回您的请求。

您需要将回调函数作为第二个参数传递,因此代码如下所示:

var findUserbyUsername=function(username, cb)
{
    db.users.find({email:username}, cb);
}
module.exports.findUser=findUserbyUsername;

然后你可以像这样调用函数:

dbutil.findUser('xxxx@gmail.com', function(err, username) {
    if (err) {
      // Handle err
    } else {
      // Handle username
    }
})
于 2012-06-07T08:55:43.967 回答