《告别回调地狱!三种写法带你玩转 JavaScript 异步》

🚀 从回调地狱到优雅异步:三种写法带你一步步进化

在前端开发中,我们经常会遇到这样的需求:

  1. 获取用户信息
  2. 根据用户 ID 获取订单信息
  3. 根据订单 ID 获取物流信息

这是一个典型的"多步骤依赖"的异步任务,如果用不同的方式实现,会有完全不同的代码风格和可维护性。

今天,我们就用同一个例子,演示 回调写法 → Promise → async/await 三种方式的演变,让你彻底告别"回调地狱"。


你觉得这三种写法哪个更好理解理解?把你的想法打在评论区!


1.回调写法


2.promise 写法


3.async/await 写法


语法介绍

Promise:

一句话 : Promise 是JavaScript 用来处理 异步函数 的一种机制,让你避免"回调地狱"(callback hell)。

Promise 的状态

一个Promise有三种可能的状态:

  1. pending(待定) :初始状态,既不是成功,也不是失败。
  2. fulfilled(已实现) :意味着操作成功完成。
  3. rejected(已拒绝) :意味着操作失败。

代码示例:展示不同状态的Promises

ini 复制代码
let fulfilledPromise = Promise.resolve('成功');
let rejectedPromise = Promise.reject('失败');

fulfilledPromise.then(value => console.log(value)); // 输出:成功
rejectedPromise.catch(error => console.log(error)); // 输出:失败

async 和 await:

一句话async/awaitPromise 的语法糖,让异步代码看起来像同步代码。

async:

通过在函数声明前加上async关键字,可以将任何函数转换为返回Promise的异步函数。这意味着你可以使用.then().catch()来处理它们的结果。

await:

awaitasync 函数内部使用 await 关键字可以暂停函数的执行,等待一个 Promise 被解决(resolve)或拒绝(reject),之后再继续执行后续代码,从而使异步代码看起来更像同步代码,提升可读性。


更详细的promise学习大家可以看阮一峰的ES6:Promise 对象 - ECMAScript 6入门

相关推荐
Cobyte2 小时前
1.基于依赖追踪和触发的响应式系统的本质
前端·javascript·vue.js
老神在在0012 小时前
【Selenium 自动化精讲】浏览器弹窗与登录界面的本质区别 & 实操指南
javascript·学习·selenium·测试工具·自动化
前端小咸鱼一条2 小时前
16.迭代器 和 生成器
开发语言·前端·javascript
前端小阳3 小时前
JavaScript原型链
javascript
早點睡3903 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-collapsible
javascript·react native·react.js
前端Hardy4 小时前
别再手写代码了!2026 前端 5 个 AI 杀招,直接解放 80% 重复劳动(附工具+步骤)
前端·javascript·面试
SuperEugene4 小时前
Element Plus/VXE-Table UI 组件库规范:统一用法实战,避开样式冲突与维护混乱|工程化与协作规范篇
前端·javascript·vue.js·ui·前端框架·element plus·vxetable
前端Hardy4 小时前
前端工程师必备的 10 个 AI 万能提示词(Prompt),复制直接用,效率再翻倍!
前端·javascript·面试
BioRunYiXue4 小时前
Nature Methods:CellVoyager 自主 AI 智能体开启生物数据分析新时代
大数据·开发语言·前端·javascript·人工智能·数据挖掘·数据分析
网络点点滴5 小时前
Vue3中Suspense的使用
前端·javascript·vue.js