IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> ES6 Promise和ES7async、await -> 正文阅读

[JavaScript知识库]ES6 Promise和ES7async、await

Promise

.then方法

then((resolve)=>{},(reject)=>{});两个函数,第一个表示成功之后的处理,第二个表示失败的处理

如果只对失败进行处理,则第一个函数传null

then(null,(reject)=>{})

如果只对成功进行处理,则第二个函数可以不传

then((res)=>{});

catch方法

当只对错误的进行处理时,等效于 使用catch();

catch(reject) == then(null,(reject)=>{});  

Promise的链式调用

  1. then方法必定返回一个新的Promise;

    可以理解为后续处理也是一个任务;

  2. 新任务的状态取决于后续处理:

    • 若没有相关的后续处理,新任务的状态和前任务一致,数据为前任务的数据
    • 若有后续处理但还未执行,新任务挂起;
    • 若后续处理执行了,则根据后续处理的情况,确定新任务的状态
      • 后续处理执行无错,新任务的状态为完成,数据为后续处理的返回值;
      • 后续执行有错,新任务的状态为失败,数据为异常对象;
      • 后续执行后返回的是一个任务的对象,新任务的状态和数据,与该任务对象一致;
const pro = new Promise((resolve)=>{
    console.log("学习");
    resolve();
});
const pro2 = pro.then(()=>{
    console.log('考试')
});
console.log(pro2);

总之:后面任务的状态,如果有相关的处理,一定要看处理的过程,不管是对成功的处理,还是对失败的处理;如果前面的任务成功了,就看成功的处理,如果前面的任务失败了,就看失败的处理;看处理的过程有没有问题,如果没有问题,pro2就成功,有问题就失败。

总结:

  1. 如果前面任务(pro)状态是成功,那么看后续(pro2)处理;如果后续是对成功的状态进行处理,那么pro2的结果,就是这个后续处理return的返回值;
  2. 如果前面的任务(pro)状态是成功,那么看后续(pro2)处理,如果后续没有对成功进行处理,那么这个pro2的结果,就等同于前面任务pro状态;
  3. 如果前面的任务(pro)状态是成功,那么看后续(pro2)处理,如果后续是对成功的状态进行处理,但是return的是一个新的 Promise对象,这时候,pro2的结果等同于,这个新的Promise对象的状态;
  4. 如果前面的任务(pro)状态是没有调用,或者很长时间才有返回值,后续也进行处理,那么pro2的结果等同于前面任务(pro)状态;

工作中的格式

// 任务成功后,执行处理,失败则执行处理
pro.then(成功处理1).catch(失败处理2);

// 任务成功后,依次执行处理1,2
pro.then(处理1).then(处理2);

// 任务成功后,依次执行处理1,处理2、若任务失败或前面的处理有错,执行3
pro.then(处理1).then(处理2).catch(处理3);

Promise的静态方法

  1. Promise.resolve(data); 直接返回一个完成状态的任务

  2. Promise.reject(data); 直接返回一个拒绝状态的任务

  3. Promise.all(任务数组); 返回一个任务

? 任务数组全部成功则成功,任何一个失败则失败

const pro = Promise.all([
      Promise.resolve(1),
      Promise.reject(2),
      Promise.resolve(3),
    ]);
  
    setTimeout(()=>{
      console.log(pro); // rejected  2;
    },1000)
  1. Promise.any(任务数组) 返回一个任务

? 任务数组任一成功则成功,任务全部失败则失败

const pro = Promise.all([
      Promise.resolve(1),
      Promise.reject(2),
      Promise.resolve(3),
    ]);
  
    setTimeout(()=>{
      console.log(pro); // fulfilled  1;
    },1000)
  1. Promise.allSettled(任务数组) 返回一个任务

    ? 任务数组全部已决则成功,任务全部失败则失败

  2. Promise.race (任务数组) 返回一个任务

    ? 任务数组任一已决则已决,状态和其一致。

async await

消除回调

有了Promise之后,异步任务有了一种统一的处理方式

有了统一的处理方式,ES官方就可以对其进一步优化

ES7退出了两个关键字asyncawait,用于更加优雅的表达Promise;

async

async关键字用于修饰函数,被它修饰的函数,一定返回Promise

async function method1(){
	return 1;  // 该函数返回值是Promise完成后的数据
}
method(); // Promise { 1 }

async function method2(){
    return Promise.resolve(1);  // 若返回的是Promise,则method2得到的Promise状态和其一致。相当于没有写async
}
method2(); // Promise { 1 }


async function method3(){
    throw new Error(1);   // 若执行过程报错,则任务是rejected
}
method3();

await

await关键字表示等待某个Promise完成,它必须用于async函数中

async function method(){
    const n = await Promise.resolve(1);
    console.log(n);
}

// 上面代码等同于
function method(){
    return new Promise((resolve,reject)=>{
        Promise.resolve(1).then(n=>{
            console.log(n);
            resolve(1);
        })
    })
}

await也可以等待其他数据

async function method(){
    const n = await 1; // 等同于await Promise.resolve(1);
}
method();


async function test(){
    return 123;
}

async function m(){
    const data = await test();
    console.log(data);
}
m();

如果需要针对失败的任务进行处理,可以使用try-catch 语法

async function method(){
    try{
        const n = await Promise.reject(123); // 失败
        console.log('成功',n);
    }
    catch(err){
        console.log('失败',err);
    }
}
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-29 18:55:53  更:2022-06-29 18:58:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:58:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码