【一起来烧脑】读懂Promise知识体系
知识体系
Promise基础语法,如何处理错误,简单介绍异步函数
内容
错误处理的两种方式:
reject('错误信息').then(null, message => {})
throw new Error('错误信息').catch(message => {})
推荐第二种
4个案例promise
// 1
doSomething().then(function () {
return doSomethingElse();
});
// 2
doSomething().then(function () {
doSomethingElse();
});
// 3
doSomething().then(doSomethingElse());
// 4
doSomething().then(doSomethingElse);
.then()
状态响应函数可以返回新的Promise,或其它值
如果返回新的Promise,那么下一级.then()
会在新Promise状态改变之后执行
如果返回其它任何值,则会立刻执行下一级.then()
.then()
接受两个函数作为参数:
fulfilled
和rejected
.then()
返回一个新的Promise实例,所以它可以链式调用
当前面的Promise状态改变时,.then()
根据其最终状态,选择特定的状态响应函数执行
可以有多个then,成为队列,每个then都会返回一个新的promise实例
[外链图片转存失败(img-jXpVtXtc-1563275786816)(https://upload-images.jianshu.io/upload_images/11158618-ba6cb93c0c741859.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
promise状态
Promise状态发生改变,会触发.then()
里的响应函数处理后续步骤。
Promise状态一经改变,不会再变。
promise 结构!!
new Promise(
// 执行器
function (resolve, reject) {
// 一段耗时很长的异步操作
resolve(); // 数据处理完成
reject(); // 数据处理出错
}
).then(function A() {
// 成功,下一步
}, function B() {
// 失败
});
Promise.race()
常见用法:
把异步操作和定时器放在一起
如果定时器先触发,就认为超时,告知用户
thenable就是有一个then()函数的对象
.then( value => {
console.log(value, 'World');
return Promise.resolve(new Promise( resolve => {
setTimeout(() => {
resolve('Good');
}, 2000);
}));
})
.then( value => {
console.log(value, 'evening');
return Promise.resolve({
then() {
console.log('everone');
}
})
});
Promise.all 与map
把所有文件读出之后再处理,所以用到了promise.all()
const FileSystem = require('./FileSystem');
function findLargest(dir){
return FildSystem.readDir(dir, 'utf-8')
.then( files => {
return Promise.all( files.map( file=> {
return new Promise(resolve => {
fs.stat(path.join(dir, file), (err, stat) => {
if(err) throw err;
if(stat.isDirectory()) {
return resolve({
size: 0
});
}
stat.file = file;
resolve(stat);
});
});
}));
})
Promise 释义
Promise对象用于异步计算
一个Promise表示一个现在,将来或永久不可能可用的值
主要用于异步计算
可以将异步操作队列化,按住期望的顺序执行,返回符合预期的结果
可以在对象之间传递和操作Promise,帮助我们处理队列
异步产生的原因
异步操作的常用语法:
document.getElementById('start').addEventListener('click', start, false);
function start() {
// 响应事件
}
// jquery
$('#start').on('click', start);
回调:
// 比较常见的有 ajax
$.ajax('http://baidu.com', {
success: function (res) {
// 这里就是回调函数了
}
});
// 或者在页面加载完毕后回调
$(function () {
// 这里也是回调函数
});
异步操作以事件为主
回调主要出现在Ajax和File API
这个时候问题尚不算严重
异步回调的问题
遍历目录,找到最大的文件
const fs = require('fs');
const path = require('path');
function findLargest(dir, callback) {
fs.readdir(dir, function (err, files) {
if (err) return callback(err);
let count = files.length;
let errored = false;
let stats = [];
files.forEach( file => {
fs.stat(path.join(dir, file), (err, stat) => {
if(errored) return;
if(err) {
errored = true;
return callback(err);
}
stats.push(stat);
Promise 简介
new Promise(
// 执行器
function (resolve, reject) {
// 一段耗时很长的异步操作
resolve(); // 数据处理完成
reject(); // 数据处理出错
}
)
.then(function A() {
// 成功,下一步
},function B() {
// 失败,做相应处理
});
Promise是一个代理对象,它和原先要进行的操作并无关系。
它通过引入一个回调。
Promise有3个状态
pending [待定] 初始状态
fulfilled [实现] 操作成功
rejected [被否决] 操作失败
promise状态发生改变,就会触发.then()
里的响应函数出来了后续步骤。
Promise状态一经改变,不会再变。
[外链图片转存失败(img-gA23f1q6-1563275786818)(https://upload-images.jianshu.io/upload_images/11158618-10641ebb84f7caa1.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
最简单的实例
定时器
new Promise( resolve => {
setTimeout( () => {
resolve('hello');
}, 2000);
})
.then( value => {
console.log( value + 'world');
});
两步执行的范例
new Promise( resolve => {
setTimeout( () => {
resolve('hello');
}, 2000);
})
.then( value => {
console.log(value);
return new Promise( resolve => {
setTimeout( () => {
resolve('world')
}, 2000);
});
})
.then(value => {
console.log(value + 'world');
});
对已完成的 Promise 执行 then
let promise = new Promise(resolve => {
setTimeout(() => {
console.log('the promise fulfilled');
resolve('hello,world');
}, 1000);
});
setTimeout( () => {
promise.then( value => {
console.log(value);
});
}, 2000);
then 里不返回 Promise
[外链图片转存失败(img-pb1Hlk9O-1563275786820)(https://upload-images.jianshu.io/upload_images/11158618-a10353f9e0f93eb3.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
then 的嵌套
[外链图片转存失败(img-ea42h6rY-1563275786825)(https://upload-images.jianshu.io/upload_images/11158618-588081b6b6e3b971.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
.then
的链式调用
[外链图片转存失败(img-VtGxiKXk-1563275786830)(https://upload-images.jianshu.io/upload_images/11158618-e92fb29df8b04954.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
console.log('start');
new Promise( resolve => {
console.log('Step 1');
setTimeout(() => {
resolve(100);
}, 1000);
})
.then( value => {
return new Promise(resolve => {
console.log('Step 1-1');
setTimeout(() => {
resolve(110);
},1000);
})
.then( value=> {
console.log('Step 1-2');
return value;
})
.then( value=> {
console.log('Step 1-3');
return value;
});
})
.then(value=> {
console.log(value);
console.log('Step 2');
});
Promise的四种情况:
doSomething()
.then(function(){
return doSomethingElse();
})
.then(finalHandler);
第一步执行,doSomething,第二步执行,doSomethingElse(undefined),第三步执行,finalHander(resultOfDoSomethingElse)
doSomething()
.then(function () {
doSomethingElse();
})
.then(finalHander);
第一步执行doSomething,第二步执行doSomethingElse(undefined),findHandler(undefined)
doSomething()
.then(doSomethingElse())
.then(finalHandler);
第一步,doSomething,doSomethingElse(undefined),第二步,finalHandler(resultOfDoSomething)
doSomething()
.then(doSomethingElse)
.then(finalHandler);
第一步doSomething,第二步doSomethingElse(resultOfDoSomething),第三步,finalHandler(resultOfDoSomethingElse)
这四项承诺有什么区别?
doSomething().then(function () {
return doSomethingElse();
});
doSomething().then(function () {
doSomethingElse();
});
doSomething().then(doSomethingElse());
doSomething().then(doSomethingElse);
错误处理
Promise会自动捕获内部异常,并交给rejected响应函数处理。
[外链图片转存失败(img-2Le2Nzt1-1563275786832)(https://upload-images.jianshu.io/upload_images/11158618-bd6dff5eebfe6a77.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-pangcVZg-1563275786833)(https://upload-images.jianshu.io/upload_images/11158618-0021384fa4d70345.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
错误和then连用
.catch + .then()
[外链图片转存失败(img-rvSdiq7W-1563275786838)(https://upload-images.jianshu.io/upload_images/11158618-1edf0bfcd0107e78.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-MpdUSfFV-1563275786840)(https://upload-images.jianshu.io/upload_images/11158618-fa8d43f841c51a52.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-L54XZ3uj-1563275786841)(https://upload-images.jianshu.io/upload_images/11158618-2e2a6b113517180d.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
Promise.all
[外链图片转存失败(img-jx0vSCMh-1563275786844)(https://upload-images.jianshu.io/upload_images/11158618-0114d601fb831a9a.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-n7lgskt8-1563275786847)(https://upload-images.jianshu.io/upload_images/11158618-08e50150a2c6e4b0.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-ttBgxamO-1563275786849)(https://upload-images.jianshu.io/upload_images/11158618-c9f412f63d3d4713.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-WKcZVtZU-1563275786850)(https://upload-images.jianshu.io/upload_images/11158618-16ccd20121a0d98a.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
与 .map 连用
[外链图片转存失败(img-wrW94rpj-1563275786851)(https://upload-images.jianshu.io/upload_images/11158618-d519d4839f785ac4.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
实现队列
[外链图片转存失败(img-L3iLa9zV-1563275786851)(https://upload-images.jianshu.io/upload_images/11158618-506f93918620bbfd.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-PB1b4bEI-1563275786854)(https://upload-images.jianshu.io/upload_images/11158618-371080deebd867fb.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-N2aSBf78-1563275786855)(https://upload-images.jianshu.io/upload_images/11158618-e655fb40dbc0d9ae.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-9ETjmwV6-1563275786856)(https://upload-images.jianshu.io/upload_images/11158618-1acd9aa01d2f44a6.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-cNWApSMG-1563275786858)(https://upload-images.jianshu.io/upload_images/11158618-5dbd4a81a3cc37d7.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
[外链图片转存失败(img-ORm5ywmt-1563275786859)(https://upload-images.jianshu.io/upload_images/11158618-b50863e2d2f4c084.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
实现爬虫
[外链图片转存失败(img-G88je6rV-1563275786860)(https://upload-images.jianshu.io/upload_images/11158618-b25e8fd0117747a7.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
Promise.resolve
Promise.reject
Promise.race
class Confirm {
constructor() {
this.promise = new Promise( (resolve, reject) => {
this.confirmButton.onClick = resolve;
this.cancelButton.onClick = reject;
});
}
}
异步函数
async/await
[外链图片转存失败(img-uPT4NB5I-1563275786863)(https://upload-images.jianshu.io/upload_images/11158618-04ff4db56e06cf7b.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
请点赞!因为你的鼓励是我写作的最大动力!
[外链图片转存失败(img-v0kSdgvF-1563275786868)(//upload-images.jianshu.io/upload_images/11158618-f0c11041a76563e7?imageMogr2/auto-orient/strip|imageView2/2/w/1240 “喜欢我就关注我”)]
吹逼交流群:711613774
[外链图片转存失败(img-GBd05T10-1563275786870)(//upload-images.jianshu.io/upload_images/11158618-d9d64fa290371ea5.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)]
【一起来烧脑】读懂Promise知识体系的更多相关文章
- 【一起来烧脑】读懂HTTP知识体系
背景 读懂HTTP很重要,参加过面试的小伙伴都很清楚,无论是技术面试面试题出得怎样,都有机会让你讲解一下HTTP,大部分都会问一下. 面试官:考考你网络协议的知识,TCP协议和UDP协议的区别,HTT ...
- 【一起来烧脑】读懂WebApp知识体系
背景 很多小白知道什么是app,但是却不知道什么是webapp呢,webapp是指用HTML5编写的移动web应用 一个webapp可以在pc端,Android端,ios端进行运行 webapp开发的 ...
- 【一起来烧脑】读懂JQuery知识体系
背景 在现在就业的过程中,会运用JQuery是你的加分项,那么什么是JQuery,嗯,jquery是JavaScript的函数库,是一种轻量级的JavaScript库,写得少,做的多,导致jQuery ...
- 【转】一篇文章读懂人力资源三支柱体系(COE・BP・SSC)
通过人力资源转型,提升效率和效能 作者:Sharon Li,翰威特大中华区咨询总监. 杰克韦尔奇曾说过“人力资源负责人在任何企业中都应该是第二号人物”,但在中国,99%的企业都做不到.原因很简单, ...
- 一文读懂 Java 异常体系
写程序的时候,编辑器会提示错误,关键字拼错了,语法不符合规则,不符合泛型:程序编译的时候,编译器会提示错误,检查是否符合 Java 的语法规范,没有通过编译器检查的程序就无法编译,也就无法运行.这些都 ...
- 一篇文章,读懂Netty的高性能架构之道
一篇文章,读懂Netty的高性能架构之道 Netty是由JBOSS提供的一个java开源框架,是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持,作为一个异步NIO框架, ...
- web前端知识体系总结
1. 前言 大约在几个月之前,让我看完了<webkit技术内幕>这本书的时候,突然有了一个想法.想把整个web前端开发所需要的知识都之中在一个视图中,形成一个完整的web前端知识体系,目的 ...
- 一文读懂UGC:互联网上的生态秘密
转载自近乎: UGC(User- Generated Content)用户原创生产内容,它是相对于PGC(Professionally-produced Content)专业生产内容的一种内容来源,简 ...
- 自己总结的web前端知识体系大全【欢迎补充】
1. 前言 大约在几个月之前,让我看完了<webkit技术内幕>这本书的时候,突然有了一个想法.想把整个web前端开发所需要的知识都之中在一个视图中,形成一个完整的web前端知识体系,目的 ...
随机推荐
- Oracle——无法在查询中执行 DML 操作
今天在调用Oracle Function遇到一个异常
- DuplexChannel
[ServiceContract(Namespace = "http://xx.com", CallbackContract = typeof(Ipub_c))] public i ...
- H5打开app指定页面(H5+app项目)
H5+app项目,在HBuilderX中设置 详情参考官方 https://ask.dcloud.net.cn/article/64 给h5+app设置scheme值,作用:在其它app和h5页面中启 ...
- redis 异常 MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk
MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. 解决方 ...
- 过滤器实现Token验证(登录验证+过期验证)---简单的实现
功能:登录验证+过期验证+注销清除cookie+未注销下关闭或刷新浏览器仍可直接访问action概述:token只存在客户端cookie,后端AES加密+解密+验证,每一次成功访问action都会刷新 ...
- Linux-排JOB定时任务
排job的3种方法,at方法只能执行一次,crontab可循环执行比较灵活,anacrontable可以检测job是否正常执行,没有执行就会重新执行比较智能一些,但是要执行的指令脚本要 放到相应的 ...
- uWSGI+django+nginx的工作原理流程与部署历程
一.前言献给和我一样懵懂中不断汲取知识,进步的人们. 霓虹闪烁,但人们真正需要的,只是一个可以照亮前路的烛光 二.必要的前提2.1 准备知识 django一个基于python的开源web框架,请确保自 ...
- 【转】DSP动态内存分配函数的使用
DSP里的动态内存分配,其分配的内存区域在在堆(heap)中.同时DSP里动态分配内存的函数还有calloc以及reclloc.这些动态分配的内存放置在.system段的全局池或堆(heap)中.因此 ...
- STL详细介绍(更新中~~~)
目录 string string的常见构造函数 string与char *(或const char*)之间的转换 string 转化为const char* const char* 转化为string ...
- mysql in条件查询到底会不会用到索引
MySQL 的 in 查询在 5.5 以上的版本中存储引擎都是 innodb 的,正常情况下会走索引的!至于 MyISAM 没试过! 如果是 5.5 之前的版本确实不会走索引的,在 5.5 之后的版本 ...