$q.all() 的异步处理问题

 

html:

<div ng-app>
  <div ng-controller="PromiseCtrl">
      {{result}}
  </div>
</div>

js:

function PromiseCtrl($scope, $q, $timeout) {
    // Our promise function with its delay as argument
    var getPromise = function(delay) {
        // Creates a Deferred object
        var deferred = $q.defer();
                       
        $timeout(function() {
            // Resolve the promise at the end of the delay if said delay was > 0
            if(delay > 0) {
                deferred.resolve("Success");
            } else {
                deferred.reject("Fail");
            }
        }, delay);
        
        // The promise of the deferred task
        return deferred.promise;
    };
    
    // Init
    $scope.result = "Waiting";
    
    /*
     * Combines multiple promises into a single promise
     * that will be resolved when all of the input promises are resolved
     */
    $q.all([
            getPromise(1000),
            getPromise(2000),
            getPromise(3000) // <--- Try something less than 0
        ]).then(function(value) {
        // Success callback where value is an array containing the success values
        $scope.result = value;       
    }, function(reason) {
        // Error callback where reason is the value of the first rejected promise
        $scope.result = reason;
    });
}

输出:["Success","Success","Success"]

 

$scope.falseList = [];
angular.forEach($scope.uploadDataList, function(value,index){
    $scope.uploadData = value;
    $scope.uploadData.name = $scope.IPSUser.name;
    $scope.uploadData.part = inds;

    var requests = [];
    requests.push($http.post($scope.URL+"zhuanlistatus/addZhuanliStatus",$scope.uploadData));
    $q.all(requests).then(function(value) {
        console.log("value",value);
        // Success callback where value is an array containing the success values
        if(value[0].data.result){
            if(index == $scope.uploadDataList.length-1) {
                layer.alert("通知书添加成功",{time:2000});
                ngDialog.closeAll();
            }
        }else{
            $scope.falseList.push(value[0].config.data);
            ngDialog.closeAll();
            if(index == $scope.uploadDataList.length-1) {
                ngDialog.open({
                    template: 'html/maintain/falseListPage.html',
                    className: 'ngdialog-theme-plain',
                    width: '40%',
                    scope: $scope,
                    cache: false
                });
            }
        }
    }).catch(function(err) {
        // Error callback where reason is the value of the first rejected promise
        layer.alert(err);
    });
},$scope.falseList);

 

参考文章:

1、http://jsfiddle.net/jsengel/mc3p01nb/

2、https://blog.csdn.net/shidaping/article/details/52398925

3、https://www.cnblogs.com/angel1254/p/6603411.html

转载于:https://www.cnblogs.com/miny-simp/p/9156060.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值