promise用法

4 篇文章 1 订阅
3 篇文章 0 订阅

一、什么是promise

promise是ES6异步编程的一种解决方案(目前最先进的解决方案是async和await的搭配(ES8),但是她们是基于promise的),从语法上讲,promise是一个对象或者说是构造函数,用来封装异步操作并可以获取其成功或失败的结果。

二、promise的优点

1、可以避免多层异步调用嵌套问题(回调地狱)
2、promise对象提供了简洁的API,使得控制异步操作更加容易(js执行机制导致的异步问题)

三、promise的三种状态

1、pending:等待中,或者进行中,表示还没有得到结果
2、resolved(fulfilled):已经完成,表示得到了我们想要的结果,可以继续往下执行
3、rejected:也表示得到结果,但是由于结果并非我们所愿,因此拒绝执行

四、promise用法:

①promise的实例方法:

let p = new Promise((resolve,reject)=>{
  //做一些异步操作
  }
);

Promise的构造函数接受一个参数:函数,并且这个函数需要传入两个参数:
resolve:异步操作执行成功后的回调函数
reject:异步操作执行失败后的回调函数
执行第一个参数之后就会改变当前promise为 已完成 状态;
执行第二个参数之后就会变为 已拒绝 状态;

②then方法:

then方法中有两个回调函数作为参数,如果Promise的状态为resolved(已经完成)则执行第一个回调函数;
例如:p.then( ( ) => { } , ( ) => { } )
调用resolve改变状态时,传递的参数会作为then方法的第一个回调函数的参数;
调用reject改变状态时,传递的参数会作为then方法的第二个回调函数的参数;

一般reject( new Error(‘reason’) )

then方法什么时候执行:
当Promise的状态由pending → resolved的时候执行第一个回调函数;
当Promise的状态由pending → rejected的时候执行第二个回调函数;
then方法执行后的返回值是一个新的Promise对象;

let p = new Promise((resolve,reject)=>{
   resolve();
} );
let p2 = p.then(
   () => { },//执行第一个回调函数
   () => { }
).then().then()
//返回的对象是Promise对象,也有then方法,所以可以不断地调用下去

then方法返回的Promise对象的状态改变:看调用这个then方法的状态,默认状态是resolved,如果想要rejected状态则需手动修改;

let p = new Promise((resolve,reject) => {
  resolved();
  //这个时候调用了resolve方法,所以状态是resolved
});
//p对象的状态从pending变成resolved
let p2 = p.then(
  (data)=>{
    //没有改变它的状态,所以此时返回的promise对象还是resolved;
    console.log("此时能捕捉到resolved回调数据")
  },
    () => { }
).then(
  (data) => {
    return new Promise((resolve,reject) => {
      reject (new Error('reason'));
      //此时状态已经变为rejected;
    })
  },
   () => { }
).then(
   ()=>{},
   (data)=>{
     //此时能捕捉到reject回调的数据
     console.log(data)
   }
)

then方法可以被同一个promise调用多次。

当promise成功执行的时候,所有的 onFulfilled 需按照其注册顺序依次回调
当promise被拒绝执行的时候,所有的onRejected需按照其注册顺序依次回调

then方法必须返回一个promise对象:
promise2 = promise1.then(onFulfilled,onRejected)
只要 onFulfilled 或者 onRejected 返回一个值x,promise2都会进入onFulfilled状态
如果 onFulfilled 或者 onRejected 抛出一个异常e,则 promise2 必须拒绝执行,并返回拒绝原因e
如果 onFulfilled 不是函数且 promise1 状态变为已完成,promise2 必须成功执行并返回相同的值
如果 onRejectd 不是函数且 promise1 状态变为已拒绝,promise2 必须执行拒绝回调并返回相同的据因

③catch方法

.catch方法是 .then(null,rejection) 或是 .then(undefined ,rejection)的别名,
如果promise对象状态变为resolved,则会调用then方法指定的回调函数;
如果异步操作抛出错误,状态就会变为rejected,就会调用catch方法指定的回调函数,处理这个错误。
另外,then方法指定的回调函数,如果运行中抛出错误,也会被catch方法捕获。

④其他的方法

all的用法:谁跑的慢,以谁为准执行回调。all接收一个数组参数,里面的值最终都算返回Promise对象
race的用法:谁跑的快,以谁为准执行回调

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值