2014-02-28 202 views
0

我的应用程序加载时运行的PhoneGap/AngularJS应用程序上有一项服务SQLService。它遍历很长的数组Guidelines,并为每个数据库创建一个数据库事务。我如何表示最终交易已完成?如何知道在AngularJS中完成一系列异步调用的时间?

我想有发生的情况是这样的:

In the controller, call `SQLService.ParseJSON` 
    ParseJSON calls `generateIntersectionSnippets` 
     `generateIntersectionSnippets` makes multiple calls to `getKeywordInCategory`` 
     When the final call to getKeywordInCategory is called, resolve the whole chain 
SQLService.ParseJSON is complete, fire `.then` 

我真不明白了如何在多个异步调用这里结合起来。 ParseJSON返回一个承诺,当generateIntersectionSnippets()完成时将被解决,但generateIntersectionSnippets()getKeywordInCategory进行多次调用,该调用也返回承诺。

下面是什么不起作用的简化版本(对任何错位的括号表示歉意,这是非常严格的)。

我想要发生的是为$scope.ready = 2在所有交易完成时运行。现在,只要程序通过generateIntersectionSnippets循环一次,它就会运行。

SQLService.parseJSON().then(function(d) { 
      console.log("finished parsing JSON") 
      $scope.ready = 2; 
      }); 

服务

.factory('SQLService', ['$q', 
    function ($q) { 

    function parseJSON() { 
      var deferred = $q.defer(); 

       function generateIntersectionSnippets(guideline, index) { 
        var snippet_self, snippet_other; 

        for (var i = 0; i < guideline.intersections.length; i++) { 


          snippet_self = getKeywordInCategory(guideline.line_id, snippets.keyword).then(function() { 
           //Should something go here? 
          }); 

          snippet_other = getKeywordInCategory(guideline.intersections[i].line_id, snippets.keyword).then(function() { 
           //Should something go here? 
          }); 

         } 


        } 

       deferred.resolve(); //Is fired before the transactions above are complete 

      } 

      generateIntersectionSnippets(); 

      return deferred.promise; 

    } //End ParseJSON 

    function getKeywordInCategory(keyword, category) { 
      var deferred = $q.defer(); 

      var query = "SELECT category, id, chapter, header, snippet(guidelines, '<b>', '</b>', '...', '-1', '-24') AS snip FROM guidelines WHERE content MATCH '" + keyword + "' AND id='" + category + "';", 
       results = []; 

      db.transaction(function(transaction) { 
       transaction.executeSql(query, [], 
        function(transaction, result) { 
         if (result != null && result.rows != null) { 
          for (var i = 0; i < result.rows.length; i++) { 

           var row = result.rows.item(i); 
           results.push(row); 
          } 
         } 
        },defaultErrorHandler); 
        deferred.resolve(responses); 
      },defaultErrorHandler,defaultNullHandler); 

      return deferred.promise; 

     } 




    return { 
      parseJSON : parseJSON 
     }; 
    }]); 

我会很感激在正确的模式是做承诺的链条,包括迭代了任何指导

控制器跨越多个异步交易 - 我知道我现在拥有的是不是正确的。

+0

很难按照你的代码,但你为什么不只是每交易延期,并使用'$ q.all'等待他们全部化解? – jraede

回答

2

您可以使用$q.all()来等待要解决的承诺列表。

function parseJSON() { 
    var deferred = $q.defer(); 
    var promiseList = []; 

    for (var i = 0; i < guideline.intersections.length; i++) { 
     promiseList.push(getKeywordInCategory(guideline.line_id, snippets.keyword)); 
     promiseList.push(getKeywordInCategory(guideline.intersections[i].line_id, snippets.keyword)); 
    } 

    $q.all(promiseList).then(function() { 
     deferred.resolve(); 
    }); 

    return deferred.promise; 

} //End ParseJSON 
+0

这正是我所要求的 - 我并不知道$ q.all。当然,Angular会有这样的内置内容!感谢指针。 – Ila

相关问题