蓝鸟承诺 - 每个功能

时间:2015-07-31 12:50:32

标签: node.js promise sails.js bluebird

提前感谢您的帮助。

在使用Bluebird承诺时,我有一系列承诺在运行。在最后一个承诺期间,我想为数组中的每个对象多次运行一个函数。

下面是伪代码:

var userArray = [ 
    {
        name: "John",
        email: "John@email.com"

    },
    {
        name: "Jane",
        email: "jane@email.com"
    }]; 

var functionOne = function() {
    //returns Promsie object
};

var functionTwo = function() {
    //returns promise object
};

var createUser = function(user) {
    return User.findOrCreate({email: user.email},{
        name: user.name,
        email: user.email
    });
};

functionOne()
    .then(functionTwo)
    .each(createUser(userArray))
    .then(function onComplete() {
        console.log("Complete");
    })
    .catch(function onError() {
        console.log("Um...it's not working");
    });

我知道我没有正确使用每个功能。使用Bluebird实现此目的的正确方法是什么?

3 个答案:

答案 0 :(得分:14)

据我所知,你想对数组中的元素采取一些异步操作。那么请检查以下示例:

var Promise = require('bluebird');

function createUsersFromArray(userArray){
    return Promise.each(userArray, function(signleUser){
        return createUserFunction(signleUser);
    });
}

return Promise.each(userArray, createUserFunction);

functionOne()
  .then(functionTwo)
  .then(function(){
      return createUsersFromArray(userArray);
  })
//or just .then(createUsersFromArray) if functionTwo return this array
  .then(function(createdUsers){
      //here you may retrieve users and make some magic with them
      console.log(createdUsers);
  })
  .then(function onComplete() {
      console.log("Complete");
  })
  .catch(function onError() {
      console.log("Um...it's not working");
  });

我还建议使用" all"而不是"每个"

检查以下示例:

return Promise.all(userArray.map(function(singleUser){
    return doSomethingWithUser(singleUser);
}));

return Promise.all(userArray.map(doSomethingWithUser));

'所有'如果采取了所有措施,将通知您。

如何使用承诺(最佳实践):

http://pouchdb.com/2015/05/18/we-have-a-problem-with-promises.html https://blog.domenic.me/youre-missing-the-point-of-promises/

答案 1 :(得分:5)

最直接的实施:

functionOne()
    .then(functionTwo)
    .then(function(){
      return bluebird.each(userArray, createUser);
    })
    .then(function onComplete() {
        console.log("Complete");
    })
    .catch(function onError() {
        console.log("Um...it's not working");
    });

如果要访问所有这些创建的结果,则应使用.map而不是.each。

答案 2 :(得分:2)

感谢@Roman @Yuri的帮助!我现在正在使用的代码如下:

var userArray = [ 
{
    name: "John",
    email: "John@email.com"

},
{
    name: "Jane",
    email: "jane@email.com"
}]; 

var functionOne = function() {
    //returns Promise object
};

var functionTwo = function() {
    //returns Promise object
};

var createUser = function(singleUser) {
  //returns Promise object containing creating User
};

functionOne()
    .then(functionTwo)
    .then(function() {
      return Promise.map(userArray, createUser);
    })
    .then(function onComplete(response) {
        console.log("Complete:" + JSON.stringify(response));
    })
    .catch(function onError() {
        console.log("Um...it's not working");
    });