从回调地狱到async/await:JavaScript异步执行的进化之路!

在JavaScript中,代码的异步执行是为了处理那些需要等待一段时间才能返回结果的操作,比如网络请求、文件读取等。这样的操作会阻塞程序的执行,降低用户体验。为了解决这个问题,JavaScript提供了多种异步处理方案:回调函数、Promise和async/await。

回调函数

回调函数是最早被广泛使用的异步处理方式。通过将一个函数作为参数传递给异步操作,在操作完成后调用该函数来处理结果。

javascript 复制代码
// 要求先打印Hello,然后再打印World
function a() {
// 模拟异步操作
    setTimeout(() => {
        console.log("Hello");
        b()
    }, 1000);
}

function b() {
    console.log("World");
}
a() // 输出Hello World

回调函数可以实现简单的异步操作,但当有多个异步操作需要依次执行时,就会出现回调地狱的问题。

Promise

Promise是ES6引入的一种更优雅的异步处理方式。它可以链式调用,避免了回调地狱的问题。

javascript 复制代码
// 要求先打印Hello,然后再打印World
function a() {
    return new Promise((resolve, reject) => {
        // 模拟异步操作
        setTimeout(() => {
            console.log("Hello");
            resolve();
        }, 1000);
    })
}

function b() {
    console.log("World");
}
a().then(() => {
    b();
}) // 输出 Hello World

Promise对象有三种状态:pending(进行中)、resolved(已完成)和rejected(已失败)。通过调用resolve()和reject()方法,可以改变Promise的状态。

.then()方法用于注册回调函数,当Promise的状态变为resolved时,将调用.then()中的回调函数。可以在.then()后面继续调用.then(),实现多个异步操作的链式调用

需要注意的是:

  • resolve(参数) 这个参数会被then中的回调函数接收
  • then方法会默认返回一个Promise对象,所以then2(多个调用时)可以接在then后面,但当then当中有人为返回一个Promise对象时,then2就接在人为返回的那个Promise对象后面

async/await

async/await是ES7引入的异步处理方式,使用起来更加简洁和直观。它基于Promise

  • async 相当于 return new Promise((resolve, reject) => {})
  • await 相当于 .then

通过使用async函数和await关键字提供一种更类似同步代码的写法。

javascript 复制代码
// 要求先打印Hello,然后再打印World
function a() {
    return new Promise((resolve, reject) => {
     // 模拟异步操作
        setTimeout(() => {
            console.log("Hello");
            resolve();
        }, 1000);
    })    
}

function b() {
    console.log("World");
}

(async function c() {
    await a();
    b();
})() // 输出 Hello World

在async函数内部,可以使用await关键字暂停代码的执行,等待一个Promise对象的结果。当await后面的表达式(通常是一个Promise对象)完成后,async函数将继续执行后面的代码。

使用async/await可以使异步代码看起来像同步代码,提高代码的可读性和维护性。

综上所述,JavaScript提供了回调函数、Promise和async/await等多种解决方案来处理异步执行,以提升代码质量和用户体验。

相关推荐
花海少爷3 分钟前
第十章 JavaScript的应用课后习题
开发语言·javascript·ecmascript
Amd7947 分钟前
Nuxt.js 应用中的 webpack:compiled 事件钩子
前端·webpack·开发·编译·nuxt.js·事件·钩子
生椰拿铁You16 分钟前
09 —— Webpack搭建开发环境
前端·webpack·node.js
狸克先生27 分钟前
如何用AI写小说(二):Gradio 超简单的网页前端交互
前端·人工智能·chatgpt·交互
sinat_3842410930 分钟前
在有网络连接的机器上打包 electron 及其依赖项,在没有网络连接的机器上安装这些离线包
javascript·arcgis·electron
baiduopenmap42 分钟前
百度世界2024精选公开课:基于地图智能体的导航出行AI应用创新实践
前端·人工智能·百度地图
loooseFish1 小时前
小程序webview我爱死你了 小程序webview和H5通讯
前端
小牛itbull1 小时前
ReactPress vs VuePress vs WordPress
开发语言·javascript·reactpress
菜牙买菜1 小时前
让安卓也能玩出Element-Plus的表格效果
前端
请叫我欧皇i1 小时前
html本地离线引入vant和vue2(详细步骤)
开发语言·前端·javascript