我有2个函数,都返回诺言:
var getToken = function() { var tokenDeferred = $q.defer(); socket.on('token', function(token) { tokenDeferred.resolve(token); }); //return promise return tokenDeferred.promise; } var getUserId = function() { var userIdDeferred = $q.defer(); userIdDeferred.resolve('someid'); return userIdDeferred.promise; }
现在,我有了一个清单,在这两个诺言得到解决后,我想立即更新
var topics = { firstTopic: 'myApp.firstTopic.', secondTopic: 'myApp.secondTopic.', thirdTopic: 'myApp.thirdTopic.', fourthTopic: 'myApp.fourthTopic.', };
已解决的主题应如下所示 myApp.firstTopic.someid.sometoken
myApp.firstTopic.someid.sometoken
var resolveTopics = function() { $q.all([getToken(), getUserId()]) .then(function(){ //How can I resolve these topics in here? }); }
$q.all创建一个承诺,当您通过的所有承诺均被拒绝或 任何 拒绝时,该承诺都会自动解决。
$q.all
如果像您一样将其传递给数组,则处理成功解析的函数将收到一个数组,其中每个项目都是针对相同索引的诺言的分辨率,例如:
var resolveTopics = function() { $q.all([getToken(), getUserId()]) .then(function(resolutions){ var token = resolutions[0]; var userId = resolutions[1]; }); }
我个人认为传递all对象更具可读性,这样您就可以在处理程序中获得一个对象,其中值是对应的promise的分辨率,例如:
all
var resolveTopics = function() { $q.all({token: getToken(), userId: getUserId()}) .then(function(resolutions){ var token = resolutions.token; var userId = resolutions.userId; }); }