异步数据库调用使函数不起作用

时间:2014-03-19 17:06:12

标签: javascript asynchronous ydn-db

function getNextID(number){
var maxKey = 0;
number = typeof number !== 'undefined' ? number : 1;

db.from('contributions').select('id').list().done(function(records) {

records.forEach(function(item){
    if (maxKey < item){
        maxKey = item;
    }
});

return(maxKey);

});

}

我正在使用ydn-db

这是一个使用本地存储的类 - 它是异步工​​作的,而不是AJAX!

我想要做的是在桌子上获取下一个ID(但那个位确实是无关紧要的部分)。

我遇到的问题是:

a)我是个白痴,我的范围错误maxKey

b)异步调用搞乱了一切。

此时函数总是返回'undefined' - 但是如果我用console.log(maxKey);替换return,它就可以正常工作。

有谁能告诉我如何修复此功能以便可以正确调用它?

(这是一个示例函数,所以虽然任何用于查找下一个键的内置函数都会被理解,但我真的需要知道如何从函数中返回异步项!)

我希望这很清楚 - 任何问题 - 都会消失!

2 个答案:

答案 0 :(得分:2)

function getNextID(number,callback){
var maxKey = 0;
number = typeof number !== 'undefined' ? number : 1;

db.from('contributions').select('id').list().done(function(records) {

records.forEach(function(item){
    if (maxKey < item){
        maxKey = item;
    }
});

callback(maxKey);

});

}

然后在你的代码中

getNextID(number,function(maxKey){
   // continue the code here.
});

因为您的代码是异步的,所以您无法从getNextID返回任何内容,而是承诺或使用延续(回调)。

答案 1 :(得分:1)

由于主键已排序,您只需获取第一个键即可获得最大键:

function getNextID(number,callback){

var key_range = number ? ydn.db.KeyRange.lowerBound(number, true) : null;

var reverse = true; // sort by descending order
var iter = new ydn.db.KeyIterator('contributions', key_range, reverse);

db.get(iter).done(function(maxKey) {

  callback(maxKey);

});

}