在我的自定义模块中,我有这个方法,它将查询数据库并查找我的数据库中是否存在用户名。我想要返回一些值,所以在上层我会知道查询结果。
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');
但不幸的是我没有定义.... 任何人都可以帮我解决这个问题吗?还是其他任何建议?
答案 0 :(得分: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
参数)
答案 1 :(得分:2)
这是一个异步代码,当然它不会返回任何东西。您可能需要以下内容:
app.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
}
} );
} );
答案 2 :(得分: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
}
})