4

我想在 JS 中编写一个函数,在其中循环遍历索引数据库中的表并获取表的最后修改的最大值并返回该值

function readData(){
    var trans = '';
    trans = idb.transaction(["tableName"],'readonly'); // Create the transaction
    var request = trans.objectStore("tableName").openCursor();
    request.onsuccess = function(e) {
        var cursor = request.result || e.result; 
        if(cursor) {
            // logic to  and find maximum
        } else {
            return // max last modified
        }
        cursor.continue();
    }
}

IMP--既然 onsuccess 方法是异步的,我怎样才能让它同步呢?这样我的方法 readData() 将仅在成功找到最大最后修改记录时返回。如果需要,我可以同步调用此方法(readData())以获取 2-3 个表的最后修改记录。

4

2 回答 2

5

同步 API 仅在 webworker 中可用。所以这将是第一个要求。(据我所知,目前只有 IE10 支持)

您可以提供的另一种方法是使用 JS 1.7 并使用 yield 关键字。有关它的更多信息,请看这里

我建议使用您在达到最新值时调用的 callbakck 方法。

function readData(callback){     
   var trans = '';         
   trans = idb.transaction(["tableName"],'readonly'); //Create the transaction   
   var request = trans.objectStore("tableName").openCursor();
   var maxKey;      
   request.onsuccess = function(e) {   
       var cursor = request.result || e.result;             
       if(cursor.value){             
          //logic to  and find maximum
          maxKey = cursor.primaryKey            
          cursor.continue();
       }
   } 
   trans.oncomplete = function(e) {
        callback(maxKey); 
   }
} 
于 2012-08-23T13:20:38.857 回答
1

顶部框架中的 IndexedDB API 是异步的。async 不能是同步的。但是您可以在单个事务中读取所有表。

于 2012-09-03T16:44:56.857 回答