2016-12-23 140 views
2

Iam使用jQuery获取对象4 promises作为回应,现在如何获得每个promise的resolves值?在角度我可以使用$q.all().then()它将解决所有值;但在jQuery中不起作用。下面是代码片段如何解决jQuery中的承诺链?

var _service = function() {}; 
var ec2; 

_service.prototype = { 

    init: function(formdata, cb) { 
     console.info('::init::', arguments[0]);   
     ec2 = new AWS.EC2(ec2_config); 
     return ec2.promise(); 
    }, 
    loop: function(param) { 
     console.info('createAdditionalResources params:', arguments); 
     return $.when({ 
      'fun1': this.fun1(param), 
      'fun2': this.fun2(param), 
      'fun3': this.fun3(param), 
      'fun4': this.fun4(param)  
     }).done(function(response) { 
      console.log('Done All'); 
      return response; 
     }); 
    }, 
    fun1: function (param) { 
     return something.promise(); // return promise 
    }, 
    .... 
}; 

window.obj = new _service(); 

这里我调用这个函数在我的剧本

function foo() { 
var d = $.Deferred(); 

obj.init() 
.then(function(res) { 
    return obj.loop(); 
}) 
.then(function(res) { 
    console.log(res); // this is promise chain 
    d.resolve(res); 
}) 
.catch(function(err) { 
    d.reject(err); 
}); 
return d.promise(); 
}; 

这里资源带有此{fun1: Promise, fun2: Promise, fun3:Promise, fun4:Promise }

和FUN1低于价值

fun1: Promise 
[[PromiseStatus]]: "resolved" 
[[PromiseValue]]: { InternetGateway: { Attachments:[{InternetGatewayId:"igw-6253970b"}] } 

现在如何解决价值?

+0

是的,你是对的;在第一个片段中,我只是在需要的情况下添加?我在问我们是否需要它?在第二个片段中;我在上一个**中使用了'd.resolve(response)',然后在** catch **块中使用了**块和'd.reject',并且使用了'return d.promise()'。我更新了第二个片段 –

+0

鉴于(至少在'fun1'中)无论如何你都使用本地promise,为什么不简单地去'Promise.all' ?! – Bergi

回答

1

您传递给$.when的对象不是承诺,也不是承诺,它的处理就好像它是一个基本值:它是作为分辨率给出的。

这里有一个方法来等待几个承诺的分辨率:

return $.when(
     this.fun1(), 
     this.fun2(), 
     this.fun3(), 
     this.fun4()  
    ).done(function(fun1, fun2, fun3, fun4) { 
     console.log('Done All'); 
     return {fun1, fun2, fun3, fun4}; 
    }); 

你也可以写一个小工具,让所有对象的属性来解决:

function solveProps(obj){ 
     var keys = Object.keys(obj); 
     return $.when.apply($, keys.map(k=>obj[k])).done(function(){ 
       var  solved = {}; 
       for (var i=0k i<keys.length; i++) { 
         solved[keys[i]] = arguments[i]; 
       } 
       return solved; 
     }); 
} 

有了这个工具,你只想有

return solveProps({ 
      fun1: this.fun1(), 
      fun2: this.fun2(), 
      fun3: this.fun3(), 
      fun4: this.fun4() 
    }); 
+0

我可以使用此功能的键值吗?像'fun1:this.fun1',因为我得到了所有4个答复中的承诺 –

+0

当然。我为此编辑了 –

+0

如果需要,您还可以制作一个实用程序,将对象的所有属性解析为承诺。你需要我写吗? –