1

我试图使用多个延迟与 jquery $.when 但到目前为止没有运气,这是我的代码:

var req = $.when(db.count('items'),db.values('items'),db.get('config', 1));

req.done(function(count,r,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);
    }
  }
});

我的示例不起作用,所以希望你们能帮助我,我到处寻找解决方案。谢谢

4

1 回答 1

0

我懂了。我将看到如何实现 jquery 延迟列表。尽管 ydn-db promise 有done, failandthem等,但它不是$.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()方法。应该是可行的,没有太多的开销。基本上你可以做一个适配器,如:donefailprogress

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 方法被添加到请求对象中,不再需要包装。例子

于 2013-10-01T04:21:53.260 回答