node-mysql query
返回undefined
。
这是我的代码:
Hash.prototype.GetHash = function()
{
var test;
var connection = this.config.CreateConnection();
connection.connect(function(err){
if (err)
throw err;
else
{
var query = "SELECT hash FROM test WHERE id = 1";
connection.query(query, function(err, rows, result){
if (err)
throw err;
else
{
test = rows[0].hash;
console.log(test);
}
});
connection.end(function(err){
if (err)
throw err;
});
}
});
return test;
}
console.log会给我正确的结果1a2b3c4d
。
所以。当我将此方法称为main方法时:
var h = hash.GetHash();
console.log(h);
控制台向我提供结果undefined
。
所以我尝试强制转换,从字符串类创建一个新对象:
这个对象test
像:
var test = '';
var test = new String;
var test = new String(rows[0].hash);
没有成功:\ 任何人都可以帮我解决这个问题吗?非常感谢你们!
答案 0 :(得分:3)
Node.js是异步的,你的代码Hash.prototype.GetHash = function() {}
将不起作用,因为它在调用时立即返回值,但尚未执行它。所以当你打印测试时,它会给出undefined。
要使用函数计算的test
并尝试返回,必须在函数完成后使用带有test的回调作为其参数来使用它。你必须对你的功能做一些改变。
Hash.prototype.GetHash = function(callback){
//pass callback in arguments if you want it to be provided when calling
... //compute test
//return test; Dont do return, do callback
callback(test);
}
//Your definition of callback should be
callback = function(h){
console.log(h);
}
请参阅教程以了解更多信息: