Promise 和async/await 的使用理解

1. new Promise时就会开始执行语句。
  new Promise(resolve => resolove('成功信息') )     简写:Promise.resolve('成功信息');
  new Promise((resolve,reject) => reject('错误信息') ) 简写:Promise.reject('错误信息');
 
2. new Promise中的return data语句没啥用,而要使用resolve或reject
 
3. new Promise中resolve或reject前后的代码都会先执行
 
4. Promise中必须使用resolve和reject 这样then方法才会执行,否则不执行。
   

promise.then(function(value) {
// 对应resolve的值
}, function(error) {
// 对应异常或者reject的值
});
let p1 = new Promise((resolve, reject) => {
//做一些异步操作
setTimeout(() => {
console.log('p1 - 执行完成');
//reject('我是失败');
resolve('我是成功!!');//必须使用resolve,不然后面不会执行
console.log('p1 - 执行完成2'); }, 2000);
}); let p2 = new Promise((resolve, reject) => {
//做一些异步操作
setTimeout(() => {
console.log('执行完成2');
resolve('我是成功2!!');
//return '我是成功!!';
}, 2000);
}); p1.then((data) => {
console.log("1-"+data);
return p2.then((data1) =>{
console.log("p2 -1-"+data1);
return "数据p2";
}) })
.then((data) => {
console.log("2-"+data);
return data;
})
.then((data) => {
console.log("3-"+data);
},(err) => {
console.log('3-rejected',err);
}).catch((err) => {
console.log('finally -rejected',err);
});
5. then中,要返回数据要使用return ;否则后面的then接收到的数据是undefined
  then中,return data返回的数据会包装成Promise.resolve(data)继续调用then,后面的then能接收到data
       如果没有return语句,那么默认是一个空的Promise.resolve(undefined),后面的then参数接收到的数据为undefined
  then中,return new Promise(),那么会等这个Promise调用完再执行then,即链式调用。
  then中,new Promise() 前没有return会异步执行,会立即执行后面的then,而不会等这个Promise执行完。
 
6. 异常处理,then中的第二个参数是接收错误的,会一步步通过then传下去,也可以用catch接收。
 
7. Promise.all用法:并行异步执行,所有都执行完
 
let Promise1 = new Promise(function(resolve, reject){})
let Promise2 = new Promise(function(resolve, reject){})
let Promise3 = new Promise(function(resolve, reject){}) let p = Promise.all([Promise1, Promise2, Promise3]) p.then(funciton(){
// 三个都成功则成功
}, function(){
// 只要有失败,则失败
})

8. Promise.race的用法:谁跑的快,以谁为准执行回调

  //请求某个图片资源
function requestImg(){
var p = new Promise((resolve, reject) => {
var img = new Image();
img.onload = function(){
resolve(img);
}
img.src = '图片的路径';
});
return p;
}
//延时函数,用于给请求计时
function timeout(){
var p = new Promise((resolve, reject) => {
setTimeout(() => {
reject('图片请求超时');
}, 5000);
});
return p;
}
Promise.race([requestImg(), timeout()]).then((data) =>{
console.log(data);
}).catch((err) => {
console.log(err);
});

9. async/await 简化Promise编码

     

  • async/await是写异步代码的新方式,优于回调函数和Promise。
  • async返回值是一个promise对象,async 函数内部return语句返回的值,会成为then方法调用函数的参数
  • await命令后面跟着的是一个promise对象,如果不是会自动转化为promise对象
  • await 关键字必须位于async函数内部
  • async/await是基于Promise实现的,它不能用于普通的回调函数。
  • async/await与Promise一样,是非阻塞的。
  • async/await使得异步代码看起来像同步代码,再也没有回调函数。但是改变不了JS单线程、异步的本质。
//例子1 -Promise
const makeRequest = () => {
return promise1()
.then(value1 => {
return promise2(value1)
.then(value2 => {
return promise3(value1, value2)
})
})
} //例子1 - 等价的async/await
const makeRequest = async () => {
const value1 = await promise1()
const value2 = await promise2(value1)
return promise3(value1, value2)
}
//例子2 -promise
request("ajaxA")
.then((data)=>{
//处理data
return request("ajaxB")
})
.then((data)=>{
//处理data
return request("ajaxC")
})
.then((data)=>{
//处理data
return request("ajaxD")
}) //例子2-等价的async/await
async function load(){
await request("ajaxA");
await request("ajaxB");
await request("ajaxC");
await request("ajaxD");
}

  

Promise 和async/await 的使用理解的更多相关文章

  1. Promise, Generator, async/await的渐进理解

    作为前端开发者的伙伴们,肯定对Promise,Generator,async/await非常熟悉不过了.Promise绝对是烂记于心,而async/await却让使大伙们感觉到爽(原来异步可以这么简单 ...

  2. node.js异步控制流程 回调,事件,promise和async/await

    写这个问题是因为最近看到一些初学者用回调用的不亦乐乎,最后代码左调来又调去很不直观. 首先上结论:推荐使用async/await或者co/yield,其次是promise,再次是事件,回调不要使用. ...

  3. Promise及Async/Await

      一.为什么有Async/Await? 我们都知道已经有了Promise的解决方案了,为什么还要ES7提出新的Async/Await标准呢? 答案其实也显而易见:Promise虽然跳出了异步嵌套的怪 ...

  4. callback vs async.js vs promise vs async / await

    需求: A.依次读取 A|B|C 三个文件,如果有失败,则立即终止. B.同时读取 A|B|C 三个文件,如果有失败,则立即终止. 一.callback 需求A: let read = functio ...

  5. 异步Promise及Async/Await最完整入门攻略

    一.为什么有Async/Await? 我们都知道已经有了Promise的解决方案了,为什么还要ES7提出新的Async/Await标准呢? 答案其实也显而易见:Promise虽然跳出了异步嵌套的怪圈, ...

  6. “setTimeout、Promise、Async/Await 的区别”题目解析和扩展

    解答这个题目之前,先回顾下JavaScript的事件循环(Event Loop). JavaScript的事件循环 事件循环(Event Loop):同步和异步任务分别进入不同的执行"场所& ...

  7. promise 进阶 —— async / await 结合 bluebird

    一.背景 1.Node.js 异步控制 在之前写的 callback vs async.js vs promise vs async / await 里,我介绍了 ES6 的 promise 和 ES ...

  8. js中回调函数,promise 以及 async/await 的对比用法 对比!!!

    在编程项目中,我们常需要用到回调的做法来实现部分功能,那么在js中我们有哪些方法来实现回调的? 方法1:回调函数 首先要定义这个函数,然后才能利用回调函数来调用! login: function (f ...

  9. 异步Promise及Async/Await可能最完整入门攻略

    此文只介绍Async/Await与Promise基础知识与实际用到注意的问题,将通过很多代码实例进行说明,两个实例代码是setDelay和setDelaySecond. tips:本文系原创转自我的博 ...

随机推荐

  1. 运行过程中给类添加方法 types.MethodType

    class Person(object): def __init__(self,name = None,age = None): self.name = name#类中拥有的属性 self.age = ...

  2. 9 16 模拟赛&关于线段树上二分总结

    1 考试时又犯了一个致命的错误,没有去思考T2的正解而是去简单的推了一下式子开始了漫漫找规律之路,不应该这样做的 为了得到规律虽然也打了暴力 但是还是打了一些不必要的程序 例如求组合数什么的比较浪费时 ...

  3. 剑指 Offer 58 - II. 左旋转字符串

    本题 题目链接 题目描述 我的题解 方法一:使用库函数 s.substring() 代码如下 public String reverseLeftWords(String s, int n) { ret ...

  4. Flink中的window、watermark和ProcessFunction

    一.Flink中的window 1,window简述  window 是一种切割无限数据为有限块进行处理的手段.Window 是无限数据流处理的核心,Window 将一个无限的 stream 拆分成有 ...

  5. Java基础—面向对象特性

    1.三大特性 ①.封装 所谓封装,就是将客观事物封装成抽象的类,类的数据和方法只允许可信的类或者对象操作,对不可信的类或对象进行信息隐藏.封装是面向对象的特征之一,是对象和类概念的主要特性.简单的说, ...

  6. 【模式识别与机器学习】——SVM举例

  7. 【Java】JavaMail 554错误解决方法

    一.解决连续发送多次 // 构件MimeMessage 对象,并设置在发送给收信人之前给自己(发送方)抄送一份 MimeMessage msg = mailSender.createMimeMessa ...

  8. QT QMdiArea 添加背景或添加背景图片失效问题

    说起QMdirArea 这个控件与其他控件真所不同.... 这里记一下 我踩过的坑之一,,,,, QMdiArea 默认的背景 不符合我要求,,当时我就理所当然就想往常一样给它设置颜色 万万没想到.. ...

  9. 2020-05-27:SpringCloud用了那些组件?分布式追踪链怎么做的?熔断器工作原理?

    福哥答案2020-05-27: SpringCloud分布式开发五大组件详解服务发现——Netflix Eureka客服端负载均衡——Netflix Ribbon断路器——Netflix Hystri ...

  10. Java实现经典七大经典排序算法

    利用Java语言实现七大经典排序算法:冒泡排序.选择排序.插入排序.希尔排序.堆排序.归并排序以及快速排序. 分类 类别 算法 插入排序类 插入排序.希尔排序 选择排序类 选择排序.堆排序 交换排序类 ...