Promise异步处理对象

Promise函数对象的运行机制

(一)、在peomise中有三种状态:pending初始状态、fulfilled成功状态、rejected失败状态当在这个函数内部调用resolve()方法时状态会从pending切换为fulfilled状态,并且后续一直为这个状态,当调用reject()方法时状态由pendung切换为rejected状态,在函数内部状态会自己识别并进行调用。以下代码示例:

let promise = new Promise((resolve,reject)=>{
   resolve("data");//调用这个状态切换为成功
   reject("err");//调用这个状态切换为失败
});
获取promise返回的状态值
格式1:
promise.then((data)=>{
  data为resolve内部返回的数据(resolve返回的数据)   
},(err)=>{
  err为内部失败返回的数据(reject返回的数据)
});   
格式2:
promise.then((data)=>{
  data为resolve内部返回的数据(resolve返回的数据)   
}).catch((err)=>{
   err为内部失败返回的数据(reject返回的数据)
});

(二)、async函数
async是promise和generator的语法糖,在用async修饰的函数内部不管有无return返回的都为promise对象且返回的是resolve内的数据,如果有return那么return返回的内容会成为resolve里面的参数。在async修饰的函数内部会有一个等待接收异步操作的属性await,以下为实例:

async function fn(){
    await "异步代码(promise函数)";
    await promise;  // data
    await接收到的数据为promise函数中resolve的参数值;默认只能接收resolve的值如果想要接收reject的值则需要使用如下代码:
    
    try{
       await promise;
    }catch(err){
       console.log(err);为异常代码
    }

使用async修饰的函数里面可以调用多个await来接收异步代码

posted @ 2020-08-21 19:45  walxl  阅读(259)  评论(0)    收藏  举报