首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >异步数据库调用使函数无法工作

异步数据库调用使函数无法工作
EN

Stack Overflow用户
提问于 2014-03-19 17:06:12
回答 2查看 104关注 0票数 0
代码语言:javascript
复制
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)异步调用把一切都搞砸了。

目前,函数总是返回“未定义的”-但是,如果我用console.log(maxKey);替换返回,它工作得很好。

有人能告诉我如何修复这个函数以便正确调用它吗?

(这是一个示例函数,因此,尽管任何用于查找下一个键的内置函数都会受到赞赏,但我确实需要知道如何从函数中返回异步项!)

我希望这是明确的-任何问题-开火!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-03-19 17:10:22

代码语言:javascript
复制
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);

});

}

然后在你的代码中

代码语言:javascript
复制
getNextID(number,function(maxKey){
   // continue the code here.
});

由于您的代码是异步的,所以您不能从getNextID返回任何东西,只能返回承诺或使用延续(回调)。

票数 2
EN

Stack Overflow用户

发布于 2014-03-20 02:49:26

由于主键是排序的,所以只需选择第一个键就可以得到最大键:

代码语言:javascript
复制
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);

});

}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22513148

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档