承诺:循环后执行



我想使用水线ORM在循环中创建多个条目。每个创建的对象都在数组中推送。创建所有对象后,我需要返回完整的数组。

这是我的代码:

share: function(req, res, next) {
    var params = {},
        id = req.param('id'),
        img = {},
        targets;
    if (!req.param('name')) {
      res.status(400);
      return res.json('Error.No.Name')
    }
    var promiseLoop = function(Tree) {      // Function called after creating or finding Tree to attach to
      var array = [];
      if(!req.param('targets')) return Tree; // No targets provided => exit
      targets = JSON.parse(req.param('targets'));
      _.each(targets, function(target) {
        params = {
          target : target,
          image: Tree.id,
          message : req.param('message')
        };
        Leaf
          .create(params)
          .then(function(Leaf) {
            array.push(Leaf);
          });
      });
      Tree.array = array;
      return Tree;
    }
    if (!id) {
      params.owner = req.session.user ;
      params.name = req.param('name');
      Tree
        .create(params)
        .then(function(Tree) {
          res.status(201);  // Status for image creation
          return Tree;
        })
        .then(promiseLoop)
        .then(function(data) { res.status(201); res.json(data);})
        .catch(function(err) { res.status(400); res.json(err);});
    }
  }
};

我希望树返回的数组成员等于创建的叶子数组。

但当然是部分

  Tree.array = array;
  return Tree;

被执行 填充数组。我得到的响应是我的树对象:

{
 ...,
 "array": []
}

我怎么做才能确保仅在创建所有对象后执行此部分?

提前谢谢你。

承诺知道上一个承诺何时通过then链接完成。你可以而且应该利用它。

返回来自promiseLoop的承诺:

  var promiseLoop = function(Tree) { // are you sure about that naming?
  if(!req.param('targets')) return Tree;
  targets = JSON.parse(req.param('targets'));
  var leaves = targets.map(function(target){
    return Leaf.create({ //  map each target to a leaf
        target : target,
        image: Tree.id,
        message : req.param('message')
      }); 
  });
  return Promise.all(leaves).then(function(leaves){
      Tree.array = leaves;  // assign to tree
  }).return(Tree); // finally resolve the promise with it
}

相关内容

  • 没有找到相关文章

最新更新