用Promise构造函数来解决地狱回调问题
简介
- Promise 是一个 构造函数,既然是构造函数, 那么,我们就可以 new Promise() 得到一个 Promise 的实例;
- 在 Promise 上,有两个函数,分别叫做 resolve(成功之后的回调函数) 和 reject(失败之后的回调函数)
- 在 Promise 构造函数的 Prototype 属性上,有一个 .then() 方法,也就说,只要是 Promise 构造函数创建的实例,都可以访问到 .then() 方法
- Promise 表示一个 异步操作;每当我们 new 一个 Promise 的实例,这个实例,就表示一个具体的异步操作;
既然 Promise 创建的实例,是一个异步操作,那么,这个 异步操作的结果,只能有两种状态:
- 状态1: 异步执行成功了,需要在内部调用 成功的回调函数 resolve 把结果返回给调用者;
- 状态2: 异步执行失败了,需要在内部调用 失败的回调函数 reject 把结果返回给调用者;
- 由于 Promise 的实例,是一个异步操作,所以,内部拿到 操作的结果后,无法使用 return 把操作的结果返回给调用者; 这时候,只能使用回调函数的形式,来把 成功 或 失败的结果,返回给调用者;
- 我们可以在 new 出来的 Promise 实例上,调用 .then() 方法,【预先】 为 这个 Promise 异步操作,指定 成功(resolve) 和 失败(reject) 回调函数;
举个例子
const fs = require('fs') function getFileByPaht(fpath) { var promise = new Promise(function (resolve, reject) { fs.readFile(fpath, 'utf-8', (err, dataStr) => { if (err) return reject(err); resolve(dataStr); }); }); return promise; } getFileByPaht('./files/3.txt') .then(function (dataStr) { console.log(dataStr); }, function (err) { console.log(err.message); })
Promise的内部执行顺序
用Promise的 .then()
方法解决地狱回调
注意: Promise的 reject
部分传入的函数可以为空,即可不写文件读取失败后的操作,
getFileByPath('./files/1222.txt') .then(function (data) { console.log(data); return getFileByPath('./files/2.txt'); }, .then(function (data) { console.log(data); return getFileByPath('./files/3.txt'); }) .then(function (data) { console.log(data); })
Promise中的异常处理
情况一:在读取文件出错的部分报错,但不影响后方代码的执行
getFileByPath('./files/1222.txt') .then(function (data) { console.log(data); return getFileByPath('./files/2.txt'); }, function (err) { console.log('读取失败:' + err.message); return getFileByPath('./files/2.txt'); }) .then(function (data) { console.log(data); return getFileByPath('./files/3.txt'); }) .then(function (data) { console.log(data); })
情况二:如果前面任何的Promise执行失败,就停止运行后面的方法(catch捕获机制)
getFileByPath('./files/1222.txt') .then(function (data) { console.log(data); return getFileByPath('./files/2.txt'); }) .then(function (data) { console.log(data); return getFileByPath('./files/3.txt'); }) .then(function (data) { console.log(data); }) .catch(function (err) { console.log('异常捕获: ' + err.message); })
相关推荐
VitaLemon 2020-08-23
嵌入式移动开发 2020-08-17
Web前端成长之路 2020-07-07
wbczyh 2020-07-05
iconhot 2020-06-26
tangjikede 2020-06-21
Wmeng0 2020-06-14
82244951 2020-05-31
Cricket 2020-05-31
czsay 2020-05-25
FCLAMP 2020-05-19
dageda 2020-04-21
火焰雪人 2020-05-09
yundashicom 2020-05-09
junzi 2020-04-22
xuguiyi00 2020-04-11
zhaowj00 2020-04-08
是一道经常出现在前端面试时的问题。如果只是简单的了解new关键字是实例化构造函数获取对象,是万万不能够的。更深入的层级发生了什么呢?同时面试官想从这道题里面考察什么呢?下面胡哥为各位小伙伴一一来解密。
haohong 2020-04-08
付春杰Blog 2020-03-26