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
此时函数总是返回'undefined' - 但是如果我用console.log(maxKey);
替换return,它就可以正常工作。
有谁能告诉我如何修复此功能以便可以正确调用它?
(这是一个示例函数,所以虽然任何用于查找下一个键的内置函数都会被理解,但我真的需要知道如何从函数中返回异步项!)
我希望这很清楚 - 任何问题 - 都会消失!
答案 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);
});
}