AngularJS承诺数组

时间:2015-09-21 13:37:55

标签: angularjs angular-promise

任何人都可以帮我一些Angular的承诺吗?我有以下函数应该接受一个文件对象数组,迭代它们,并上传每一个。在每次迭代期间,promise对象被推送到promises的数组。在我的upload函数中,我有一个附加cycle的{​​{1}}函数,在所有promise对象都已解析之前不应该调用它。我认为我的代码看起来是正确的,但它无法正常工作。图片上传,但会立即调用.then(),而不是cycle(files).then()数组结算。

promises

最终工作代码*

而不是将function upload(files) { var uploadCount = files.length; function cycle(files) { var promises = []; for (var i = 0; i < files.length; i++) { var deferred = $q.defer(); promises.push(deferred); var file = files[i]; Upload.upload({ url: '/photos.json', file: file }).success(function(){ $scope.progressCurrentCount += 1; deferred.resolve(); }); }; return $q.all(promises); }; cycle(files).then(function(result) { if(uploadCount > 1) { $scope.lastAction = 'uploaded ' + uploadCount + ' photos'; } else { $scope.lastAction = 'uploaded ' + uploadCount + ' photo'; } $scope.showSuccessModal = true; $scope.uploading = false; $scope.failedUploads = []; $scope.newPhotos = { token: $scope.token, files: undefined }; photoUploadBtn.removeClass('disabled'); }) }; 推送var deferred = $q.defer();进入deferred.promise数组,然后在我的promises回调中解析deferred,这不起作用,我只需将我的.success()函数推送到Upload.upload() .success(),然后将其传递给promises,即可完成所有提升。

$q.all()

1 个答案:

答案 0 :(得分:11)

您必须将承诺而不是延期承诺推送到promises阵列:

promises.push(deferred.promise);

如果您这样考虑它会有所帮助:

  • 承诺是您想要返回给消费者的只读对象
  • deferred是该只读承诺的修饰符,您希望自己保留它