Promise 的 API 理解与使用

一、promise 的 API 说明
  1. Promise 构造函数: Promise (excutor) {},如下所示:
  • executor 函数: 执行器 (resolve, reject) => {}
  • resolve 函数: 内部定义成功时我们调用的函数 value => {}
  • reject 函数: 内部定义失败时我们调用的函数 reason => {}
  • 说明: executor会在 Promise 内部立即同步调用,异步操作在执行器中执行
  1. Promise.prototype.then 方法: (onResolved, onRejected) => {},如下所示:
  • onResolved 函数: 成功的回调函数 (value) => {}
  • onRejected 函数: 失败的回调函数 (reason) => {}
  • 说明: 指定用于得到成功 value 的成功回调和用于得到失败 reason 的失败回调
    返回一个新的 promise 对象
  1. Promise.prototype.catch 方法: (onRejected) => {},如下所示:
  • onRejected 函数: 失败的回调函数 (reason) => {}
  • 说明: then() 的语法糖, 相当于: then(undefined, onRejected)
  1. Promise.resolve 方法: (value) => {},如下所示:
  • value: 成功的数据或 promise 对象
  • 说明: 返回一个成功/失败的 promise 对象
  1. Promise.reject 方法: (reason) => {},如下所示:
  • reason: 失败的原因
  • 说明: 返回一个失败的 promise 对象
  1. Promise.all 方法: (promises) => {},如下所示:
  • promises: 包含 npromise 的数组
  • 说明: 返回一个新的 promise, 只有所有的 promise 都成功才成功, 只要有一个失败了就
    直接失败
  1. Promise.race 方法: (promises) => {},如下所示:
  • promises: 包含 npromise 的数组
  • 说明: 返回一个新的 promise, 第一个完成的 promise 的结果状态就是最终的结果状态
二、promise API 的使用
  1. promiseAPIthencatch,代码如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>promise的API之then和catch</title>
</head>
<body>
  <script>
    let p = new Promise((resolve, reject) => {
      // 同步调用
      // 修改 promise 对象的状态
      reject('error');
    });

    // 执行 catch 方法
    p.catch(reason => {
      console.log(reason);
    });
  </script>
</body>
</html>
  1. promiseAPIresolve,代码如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>promise的API之resolve</title>
</head>
<body>
  <script>
    let p1 = Promise.resolve(123);
    //如果传入的参数为 非Promise类型的对象, 则返回的结果为成功promise对象
    //如果传入的参数为 Promise 对象, 则参数的结果决定了 resolve 的结果
    let p2 = Promise.resolve(new Promise((resolve, reject) => {
      reject('error');
    }));

    p2.catch(reason => {
      console.log(reason);
    });
    
  </script>
</body>
</html>
  1. promiseAPIreject,代码如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>promise的API之reject</title>
</head>
<body>
  <script>
    let p1 = Promise.reject('123');
    let p2 = Promise.reject('456');
    let p3 = Promise.reject(new Promise((resolve, reject) => {
      resolve('ok');
    }));

    console.log(p3);

  </script>
</body>
</html>
  1. promiseAPIall,代码如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>promise的API之all</title>
</head>
<body>
  <script>
    let p1 = new Promise((resolve, reject) => {
      resolve('ok1');
    });
    
    // let p2 = Promise.resolve('ok2')
    let p2 = Promise.reject('Error');
    let p3 = Promise.resolve('ok3');

    let result = Promise.all([p1, p2, p3]);
    console.log(result);

  </script>
</body>
</html>
  1. promiseAPIrace,代码如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>promise的API之race</title>
</head>
<body>
  <script>
    let p1 = new Promise((resolve, reject) => {
      setTimeout(() => {
        resolve('ok');
      }, 1000);
    });

    let p2 = Promise.resolve('success');
    let p3 = Promise.resolve('true');

    // 调用
    const result = Promise.race([p1, p2, p3]);
    console.log(result);
    
  </script>
</body>
</html>
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Promise是一种用于处理异步操作的机制,它可以容纳一个未来会结束的事件的结果。Promise具有三种状态:等待中(pending)、完成了(resolved)和拒绝了(rejected),一旦从等待状态变成其他状态,就无法再改变。 从语法上来说,Promise是一个对象,它提供了统一的API,可以用来处理各种异步操作。它的作用是解决回调地狱(callback hell)的问题,使得异步代码更加可读、可维护。 Promise的状态不受外界影响,它代表一个异步操作,并且只有异步操作的结果可以决定当前的状态。无论其他操作如何,都无法改变Promise的状态,这也是Promise的名称"承诺"的由来。 总结来说,Promise是一种用于处理异步操作的机制,它具有三种状态,提供了统一的API,并且能够解决回调地狱的问题。它的状态只由异步操作的结果决定,其他操作无法改变它的状态。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Promise理解及实现Promise](https://download.csdn.net/download/weixin_38499349/14046688)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [谈谈对Promise理解](https://blog.csdn.net/hddlsj/article/details/123029117)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值