如何避免地狱回调?

本贴最后更新于 2072 天前,其中的信息可能已经事过景迁

2019-03-20

提问

如何避免以下这种地狱回调的情况?

getData(function(a) {
  getMoreData(a, function(b) {
    getMoreData(b, function(c) {
      getMoreData(c, function(d) {
        getMoreData(d, function(e) {
          // ...
        })
      })
    })
  })
})

回答

重构返回 promises 的函数,使用最佳的 async/await 进行替换。替代回调函数导致的深层次嵌套,async/await 返回一个可以 await 的 promise,当异步数据返回后才允许以同步的方式执行下一行代码。

以上的代码可以如下进行重构:

async function asyncAwaitVersion() {
  const a = await getData()
  const b = await getMoreData(a)
  const c = await getMoreData(b)
  const d = await getMoreData(c)
  const e = await getMoreData(d)
  // ...
} 

加分回答

  • 有很多方法可以解决此类回调地狱的问题:
    • 模块化:将回调分解为独立的函数
    • 使用第三方库,如 async
    • 使用带有 Promise 的生成器
    • 从 v7 开始使用 async/await
  • 作为一个有能力的 JavaScript 开发人员,我们必须避免不断增长的缩进,使用干净且可读的代码来处理复杂的流程。

返回总目录

30 秒面试系列一

  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 8 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 43 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • KsRyY

    问题在于 Async/Await 的错误处理需要用传统的 Try/Catch 模式,有点烦。

  • Vanessa

    需要 catch 的地方都避免不了

Vanessa
我们终此一生,就是要摆脱他人的期待,找到真正的自己。 昆明