Promise

Promise

Promise 是异步编程的一种解决方案, 可以解决传统 Ajax 回调函数嵌套问题。

案例:模拟使用ajax连续发起两次请求

第一次请求monster.json获取到monster的id

json 复制代码
{
  "id": 1,
  "name": "黑山老妖"
}

第二次请求需要根据第一次获取到的id来获取monster的详细信息

json 复制代码
{
  "address": "阴曹地府-黑山",
  "skill": "翻江倒海功",
  "age": 800
}

传统的ajax方式:

javascript 复制代码
//jquery 发出 ajax 的方式
$.ajax({
    url: "data/monster.json",
    success(resultData) {	//如果请求成功了,回调处理函数 success
        console.log("第 1 次 ajax 请求 monster 基本信息=", resultData);
        //发出第二次 ajax 请求
        $.ajax({
            url: `data/monster_detail_${resultData.id}.json`,
            success(resultData) {
                console.log("第 2 次 ajax 请求 monster 详细信息=", resultData);
                //$.ajax => callback hell
            }, error(err) { //出错的回调函数
                console.log("出现异常=", err);
            }
        })
    }, error(err) {
        console.log("出现异常=", err);
    }
})

使用promise:

javascript 复制代码
	//1. 创建 Promise 对象
    //2. 构造函数传入一个箭头函数
    //3. (resolve, reject) 参数列表 resolve: 如果请求成功, 调用 resolve 函数
    //4. 如果请求失败, 调用 reject 函数
    //5. 箭头函数体, 仍然是通过 jquery 发出 ajax
    let p = new Promise((resolve, reject) => {
        //发出 ajax
        $.ajax({
            url: "data/monster.json", 
            success(resultData) {	//成功后回调函数
                console.log("promise1 结果 =", resultData);
                resolve(resultData);
            }, error(err) {
				//console.log("promise1 请求异常=", err);
                reject(err);
            }
        })
    })
    //这里我们可以继续编写请求成功后的业务
    p.then((resultData) => {
		//这里我们可以继续发出请求
		//console.log("p.then 得到 resultData", resultData);
        return new Promise((resolve, reject) => {
            $.ajax({
                url: `data/monster_detail_${resultData.id}.json`, 
				success(resultData) { //第 2 次 ajax 请求成功,回调函数
                    console.log("promise2 结果 =", resultData);
                    //继续进行下一次的请求
                    resolve(resultData);
                }, error(err) { //第 2 次 ajax 请求失败,回调函数
					//console.log("promise2 请求异常=", err);
                    reject(err);
                }
            })
        })
    }).then((resultData) => {
		//可以在这继续发起请求
    }).catch((err) => { //这里可以对多次 ajax 请求的异常进行处理
        console.log("promise 异步请求异常=", err);
    })

注意事项和使用细节:

  • 如果返回的是 Promise 对象,可以继续执行.then()
  • .then((data)=>{}) 的 data 数据是上一次正确执行后 resolve(data) 返回传入的
  • 通过多级.then() 可以对异步请求分层次请求,实现代码重排,代码逻辑更加清晰合理
  • 通过多级.then() 后面的 .catch((err) => {}) 可捕获发生异常,便于调试
相关推荐
王文?问3 分钟前
ESP32-S3 实战教程:本地语音识别控制 Web 塔防游戏,从固件到前端完整跑通
前端·游戏·语音识别
Hoshizola17 分钟前
uniapp与蓝牙设备连接详细步骤
前端·uni-app
优雅格子衫22 分钟前
uniapp 拍照相册选取后超级好用的裁剪组件,增加水印完全自定义
开发语言·前端·javascript·uni-app·vue
Dxy123931021627 分钟前
HTML如何写鼠标事件
前端·html·计算机外设
AI砖家39 分钟前
前端 JavaScript 异步处理全方案详解:从回调到 Observable
开发语言·前端·javascript
用户7138742290044 分钟前
构建现代 Web 应用的令牌安全体系:Refresh Token Rotation、HttpOnly Cookie 与 Grace Period 全解析
前端
柒和远方1 小时前
每日一学V010: 从 Python 回到前端:一个 AI Native 开发者的 JavaScript 底层基础补全
javascript
之歆1 小时前
Day21_电商详情页核心技术实战:从LESS预处理到复杂交互实现
开发语言·前端·javascript·css·交互·less
海鸥两三1 小时前
基于 Vue 3 + 高德地图的网格规划系统实战(有源码)
前端·javascript·vue.js
逸A1 小时前
某里v2反混淆 codec 化路上踩到的两个隐蔽坑:被清零的 salt 与 opaque loop bound
javascript·人工智能·目标跟踪