使用Promise的优缺点及一些常见的问题

您所在的位置:网站首页 网络的缺陷有什么 使用Promise的优缺点及一些常见的问题

使用Promise的优缺点及一些常见的问题

2024-07-12 12:47| 来源: 网络整理| 查看: 265

promise的缺点

1、无法取消Promise,一旦新建它就会立即执行,无法中途取消。

2、如果不设置回调函数,promise内部抛出的错误,不会反应到外部。

3、当处于pending状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)。

promis的优点

1.解决回调地狱(Callback Hell)问题 (1)有时我们要进行一些相互间有依赖关系的异步操作,比如有多个请求,后一个的请求需要上一次请求的返回结果。过去常规做法只能 callback 层层嵌套,但嵌套层数过多的话就会有 callback hell 问题。比如下面代码,可读性和维护性都很差的。

//引入 fs 模块(node.js) //回调地狱方式读取文件,如果还有异步还会继续回调 const fs = require('fs') fs.readFile('./a.md', (err,data1) => { fs.readFile('./b.md', (err, data2) => { fs.readFile('./c.md', (err, data3) => { let result = data1 + data2 + data3 console.log(result); }) }) })

(2)如果使用 promises 的话,代码就会变得扁平且更可读了。前面提到 then 返回了一个 promise,因此我们可以将 then 的调用不停地串连起来。其中 then 返回的 promise 装载了由调用返回的值。

//使用promise 来实现 //引入 fs 模块 const fs = require('fs') //闯将Promise对象 const p = new Promise((resolve, reject) => { //引入 fs 莫模块 const fs = require('fs') fs.readFile('./a.md', (err, data) => { resolve(data) }) }) p.then(value => { return new Promise((resolve, reject) => { fs.readFile('./b.md', (err, data) => { //这里的data为a.md value为b.md resolve([value, data]) }) }) }).then(value => { return new Promise((resolve, reject) => { fs.readFile('./c.md', (err, data) => { //这里的data为a.md+b.md //将这data 用push()方法压入value value.push(data) resolve(value) }) }) }).then(value => { //打印出value 字符转义 // console.log(value.toString()); console.log(value.join('\r\n')); })

2,更好地进行错误捕获 多重嵌套 callback 除了会造成上面讲的代码缩进问题,更可怕的是可能会造成无法捕获异常或异常捕获不可控。 (1)比如下面代码我们使用 setTimeout 模拟异步操作,在其中抛出了个异常。但由于异步回调中,回调函数的执行栈与原函数分离开,导致外部无法抓住异常。

function fetch(callback) { setTimeout(() => { throw Error('请求失败') }, 2000) } try { fetch(() => { console.log('请求处理') // 永远不会执行 }) } catch (error) { console.log('触发异常', error) // 永远不会执行 } // 程序崩溃 // Uncaught Error: 请求失败

(2)如果使用 promises 的话,通过 reject 方法把 Promise 的状态置为 rejected,这样我们在 then 中就能捕捉到,然后执行“失败”情况的回调。

function fetch(callback) { return new Promise((resolve, reject) => { setTimeout(() => { reject('请求失败'); }, 2000) }) } fetch() .then( function(data){ console.log('请求处理'); console.log(data); }, function(reason, data){ console.log('触发异常'); console.log(reason); } );

回答常见的问题(FAQ)

Q: then、catch 和 finally 序列能否顺序颠倒?

A: 可以,效果完全一样。但不建议这样做,最好按 then-catch-finally 的顺序编写程序。

Q: 除了 then 块以外,其它两种块能否多次使用?

A: 可以,finally 与 then 一样会按顺序执行,但是 catch 块只会执行第一个,除非 catch 块里有异常。所以最好只安排一个 catch 和 finally 块。

Q: then 块如何中断?

A: then 块默认会向下顺序执行,return 是不能中断的,可以通过 throw 来跳转至 catch 实现中断。

Q: 什么时候适合用 Promise 而不是传统回调函数?

A: 当需要多次顺序执行异步操作的时候,例如,如果想通过异步方法先后检测用户名和密码,需要先异步检测用户名,然后再异步检测密码的情况下就很适合 Promise。

Q: Promise 是一种将异步转换为同步的方法吗?

A: 完全不是。Promise 只不过是一种更良好的编程风格。

Q: 什么时候我们需要再写一个 then 而不是在当前的 then 接着编程?

A: 当你又需要调用一个异步任务的时候。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3