首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在angularjs中将参数传递给promise的回调

在angularjs中将参数传递给promise的回调
EN

Stack Overflow用户
提问于 2014-07-26 03:26:55
回答 2查看 20.1K关注 0票数 16

我试图弄清楚是否有任何方法可以将索引参数传递给promise的回调函数。例如。

代码语言:javascript
复制
serviceCall.$promise.then(function(object){
    $scope.object = object;
});

现在我想传入一个数组索引参数作为

代码语言:javascript
复制
serviceCall.$promise.then(function(object,i){
    $scope.object[i] = something;
});

这可以做到吗?请让我知道。

下面是代码

代码语言:javascript
复制
StudyService.studies.get({id:    
$routeParams.studyIdentifier}).$promise.then(function(study) {
$scope.study = study;
for(var i=0;i<study.cases.length;i++){
  StudyService.executionsteps.get({id:   
  $routeParams.studyIdentifier,caseId:study.cases[i].id})
      .$promise.then(function(executionSteps,i){
      $scope.study.cases[i].executionSteps = executionSteps;
      });
  }
});
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-07-26 04:04:29

为此,您可以使用closure

例如,在您的代码中,使用类似以下内容:

代码语言:javascript
复制
function callbackCreator(i) {
  return function(executionSteps) {
    $scope.study.cases[i].executionSteps = executionSteps;
  }
}
StudyService.studies.get({id: $routeParams.studyIdentifier})
  .$promise.then(function(study) {
    $scope.study = study;
    for(var i=0;i<study.cases.length;i++) {
      var callback = callbackCreator(i);
      StudyService.executionsteps.get({id: $routeParams.studyIdentifier,caseId:study.cases[i].id})
        .$promise.then(callback);
   }
});
票数 21
EN

Stack Overflow用户

发布于 2014-07-26 03:51:37

我做了类似的事情,我对每个承诺都做了承诺,然后在承诺数组上使用$q.all(),如下所示:

代码语言:javascript
复制
$q.all( arrayOfPromises )
.then(function(results) {
   console.log(results[0], results[1], results[2]);
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24963151

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档