我有JavaScript函数,它从我的本地数据库中返回所选值的数组。
var dataBase = {
select : selectFunction
}
var db = openDatabase(..);
var data=[ ];
function selectFunction() {
db.transaction(function (t) {
t.executeSql("SELECT * FROM Table", [], function (t, results) {
for (i = 0; i < results.rows.length; i++) {
data.push(results.rows.item(i));
}
});
});
return data;//return "stackoverflow" //works fine
}
我想做这样的事情
var getSelect = dataBase.select();
alert(getSelect);
如果我返回类似“stackoverflow”的字符串,这将正常工作
alert result: stackoverflow
但是如果我尝试返回'data',该函数将返回undefined
我注意到db.transaction
正在return语句后执行,我不知道如何解决这个问题。
答案 0 :(得分:4)
从异步函数返回结果时,必须使用回调函数,因为函数将在实际操作完成之前返回。您可以像这样重写您的函数:
function selectFunction(callback) {
db.transaction(function (t) {
t.executeSql("SELECT * FROM Table", [], function (t, results) {
for (i = 0; i < results.rows.length; i++) {
data.push(results.rows.item(i));
}
callback(data);
});
});
}
然后调用它,传递一个回调:
dataBase.select(function(data){
var getSelect = data
alert(getSelect);
});