javascript – 蓝鸟中的嵌套承诺

前端之家收集整理的这篇文章主要介绍了javascript – 蓝鸟中的嵌套承诺前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在试图弄清楚如何正确使用蓝鸟库的promises.我在代码中遇到了一些嵌套的promise,我注意到在bluebird文档中它的内容如下:

if you are utilizing the full bluebird API offering,you will almost never need to resort to nesting promises in the first place.

关于承诺被滥用的许多其他博客文章和嵌套是一种常规的反模式.

  1. loadCar(someUri) // jqXHR
  2. .then(function (car) {
  3. if (carHasFourDoors(car)) {
  4. loadMake(car.make)
  5. .then(function (make) {
  6. loadModel(make.model)
  7. .then(function (model) {
  8. loadCarDetails(model)
  9. });
  10. });
  11. }
  12. else if (carHasTwoDoors(car)) {
  13. loadModel(make.model)
  14. .then(function (model) {
  15. loadCarDetails(model)
  16. });
  17. }
  18. });

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

所以,我的问题是:如果存在依赖关系,我怎么能避免嵌套?也许这是我对承诺的异步性质的误解.可以这样的工作吗?

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

解决方法

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

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

  1. loadCar(someUri).then(function (car) {
  2. if (carHasFourDoors(car)) {
  3. return loadMake(car.make)
  4. else if (carHasTwoDoors(car))
  5. return make; // not sure actually where you get this from
  6. }).then(function (make) {
  7. return loadModel(make.model)
  8. }).then(loadCarDetails)

猜你在找的JavaScript相关文章