我懂了。我将看到如何实现 jquery 延迟列表。尽管 ydn-db promise 有done
, fail
andthem
等,但它不是$.Deferred
实例。需要适配器方法。
目前,使用事务如下:
var results = {};
var tx_req = db.run(function(tx_db) {
tx_db.count('items').done(function(x) {
results.count = x;
});
tx_db.values('items').done(function(x) {
results.values = x;
});
tx_db.get('config', 1).done(function(x) {
results.config = x;
});
}, ['items', 'config'], 'readonly');
req.done(function() {
var count = results.count;
var r = results.values;
var config = results.config;
var currency = config.currency;
if(count > 0){
var n = r.length;
for (var i = 0; i < n; i++) {
var id = r[i].id;
var itemId = r[i].itemId;
console.log('ID: '+id+' itemID: '+itemId+' Currency: '+currency);
}
}
results = null;
});
它有点混乱,但更高效,因为所有三个查询都在一个事务中运行。
编辑:
只需要添加返回具有,和函数的对象的promise()
方法。应该是可行的,没有太多的开销。基本上你可以做一个适配器,如:done
fail
progress
var wrap = function(req) {
req.promise = function() {
return req; // Note: req has done, fail and progress functions.
// however, jquery api demand promise to return a new deferred.
}
return req;
}
$.when(wrap(db.count('items')),wrap(db.values('items')),wrap(db.get('config', 1)));
这是jsfiddle 中的完整代码。
编辑:
从 0.8.1 版本开始,promise 方法被添加到请求对象中,不再需要包装。例子。