ES6之Promise基本用法

1.Promise相关概念

      Promise 是异步编程的一种解决方案,比传统的解决方案(回调函数和事件)更合理和更强大。它由社区最早提出和实现,ES6将其写进了语言标准,统一了语法,原生提供了Promise对象。

      所谓Promise ,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果。从语法上说,Promise是一个对象,从它可以获取异步操作的消息。

      有三种状态:Pending(进行中),Fulfilled(已成功)和Rejected(已失败)。

      Promise对象的状态改变,只有两种可能:从Pending变为Fulfilled或者从Pending变为Rejected。

      它有以下两个特点:

      1.1 对象的状态不受外界影响;

      1.2 一旦状态改变就不会再变,任何时候都可以得到这个结果。

2.基本用法

      2.1 ES6规定,Promise对象是一个构造函数,用来生成Promise实例。话不多说,上代码。

在这里插入图片描述

      可以看出,Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve和reject。它们是两个函数,由JS引擎提供,不用自己部署。

      resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;

      reject函数的作用是,将Promise对象的状态从“未完成”变为“失败”(即从 pending 变为 rejected),在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。

      2.2 Promise 实例生成以后,可以用then 方法分别指定resolved状态和rejected状态的回调函数。

在这里插入图片描述

      可以看出,then方法接受两个回调函数作为参数。第一个回调函数是Promise对象的状态变为Resolved时调用,第二个回调函数是变为Rejected时调用,执行“失败”情况的回调,更好地进行错误捕获,可选。

      2.3 不过不推荐上面的写法,then的第二个回调函数用catch代替,这样更接近同步的try/catch。

在这里插入图片描述

3.链式操作的用法

      then和catch均返回Promise,因此我们可以将 then 的调用不停地串连起来,其中 then 返回的 promise 装载了由调用返回的值。这也是其优势,解决回调地狱(Callback Hell)问题。

在这里插入图片描述

4.两个例子

      4.1 异步加载图片

在这里插入图片描述

      4.2 用Promise对象实现的 Ajax 操作

在这里插入图片描述

本文作者:Yaphets.Lee

转载请注明出处,感谢!

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ES6Promise是一种用于处理异步操作的对象。Promise对象可以表示一个异步操作的最终完成(包括成功和失败)及结果值的表示。它可以解决传统回调函数的问题,使代码更具可读性和可维护性。Promise对象有三种状态:pending(进行)、fulfilled(已成功)和rejected(已失败)。通过使用Promise对象,我们可以更好地控制和处理异步操作的结果。 ES6Promise相对于传统的回调函数具有以下优点: 1. 更好的代码结构和可读性:使用Promise可以使代码结构更清晰,减少了回调函数的层层嵌套。 2. 更好的错误处理:Promise可以通过catch方法捕获错误,并进行统一的错误处理,使错误处理更加简洁和方便。 3. 更好的异步流程控制:Promise可以通过then方法链式调用,实现更复杂的异步流程控制,避免了回调地狱的问题。 ES6Promise API包括以下方法: 1. Promise.resolve(value):返回一个解析后带有给定值的Promise对象。 2. Promise.reject(reason):返回一个带有拒绝原因的Promise对象。 3. Promise.all(iterable):返回一个Promise对象,该对象在iterable参数的所有Promise对象都已解析或拒绝后解析。 4. Promise.race(iterable):返回一个Promise对象,该对象在iterable参数的任何一个Promise对象解析或拒绝后解析。 5. Promise.prototype.then(onFulfilled, onRejected):添加解析和拒绝回调函数到Promise。 6. Promise.prototype.catch(onRejected):添加一个拒绝回调函数到Promise

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值