蓝鸟的嵌套承诺

时间:2014-06-25 15:24:16

标签: javascript promise bluebird

我试图找出如何正确使用蓝鸟库中的promises。我在代码中遇到了一些嵌套的承诺,我注意到蓝鸟文档中的内容是:

  

如果您正在使用完整的bluebird API产品,那么您几乎不需要首先采用嵌套承诺。

还有许多关于承诺被滥用的博客文章,嵌套是一种常规的反模式。

loadCar(someUri) // jqXHR
    .then(function (car) {
        if (carHasFourDoors(car)) {
            loadMake(car.make)
                .then(function (make) {
                    loadModel(make.model)
                        .then(function (model) {
                            loadCarDetails(model)
                        });
                });
        }
        else if (carHasTwoDoors(car)) {
            loadModel(make.model)
                .then(function (model) {
                    loadCarDetails(model)
                });
        }
    });

我的所有函数都返回对象。看看蓝鸟文档,似乎有多种辅助方法:all(),join(),props()。

所以,我的问题是:如果存在依赖关系,我怎么能避免嵌套呢?也许这是我对promises的异步性质的误解。这样的事情能起作用吗?

Promise.all(loadCar(someUri), loadMake(car.make), loadModel(make.model))
    .then(function(car, make, model) {
        // do logic
    });

1 个答案:

答案 0 :(得分:6)

您总是需要为控制结构嵌套,并且通常需要对传递给then()的函数表达式进行一级嵌套。这不是完全可以避免的,但可以是reduced significantly

在你的情况下,你甚至可以省略一些函数表达式并直接传递函数。

loadCar(someUri).then(function (car) {
    if (carHasFourDoors(car)) {
        return loadMake(car.make)
    else if (carHasTwoDoors(car))
        return make; // not sure actually where you get this from
}).then(function (make) {
    return loadModel(make.model)
}).then(loadCarDetails)