首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何避免承诺的“回调地狱”?

如何避免承诺的“回调地狱”?
EN

Stack Overflow用户
提问于 2016-09-30 13:10:36
回答 3查看 536关注 0票数 0

我对承诺很陌生,我想了解什么是避免承诺的“回调地狱”的正确方法,因为我和使用回调有着同样的问题。

代码语言:javascript
复制
foo(a: number): Promise<boolean>{
    return doSomething(a).then((b)=>{
        return doAnotherThing(b).then((c)=>{
            return true;
        })
    })
}

看看这个金字塔..。

你怎么能避免这种情况?

提前感谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-09-30 13:12:32

只是连锁承诺,而不是嵌套它们:

代码语言:javascript
复制
foo(a: number): Promise<boolean> {
    return doSomething(a).then((b) => {
        return doAnotherThing(b);
    }).then((c) => {
        return true;
    });
}

请参阅Objects/Promise

票数 1
EN

Stack Overflow用户

发布于 2016-09-30 13:13:51

您可以做出承诺,返回一个承诺(或任何其他值),然后用.then()进行链接。

代码语言:javascript
复制
foo(a: number): Promise<boolean>{
  return doSomething(a).then((b)=>{
      return doAnotherThing(b);
    }).then((c)=>{
      return true;
    });
}
票数 1
EN

Stack Overflow用户

发布于 2016-09-30 13:19:44

如果您使用babel,您可以使用ES2015等待。

例如:

代码语言:javascript
复制
async function foo(a) {
  var b = await doSomething(a);
  var c = await doAnotherThing(b);
  return true;
}

预置: ES2015,第3阶段

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39792360

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档