东亚银行、岚图汽车带你解锁 AIGC 时代的数字化人才培养各赛道新模式! 了解详情
写点什么

解决回调深渊的利器(二)

  • 2020-01-10
  • 本文字数:1807 字

    阅读完需:约 6 分钟

解决回调深渊的利器(二)

优点和缺点

优点:可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise 对象提供统一的接口,使得控制异步操作更加容易。


缺点:首先,无法取消 Promise,一旦新建它就会立即执行,无法中途取消。其次,如果不设置回调函数,Promise 内部抛出的错误,不会反应到外部。当处于 Pending 状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)。

Promise 的生命周期

每一个 Promise 都会经历一个短暂的生命周期:先是处于进行中 pending(Promise 对象的初始状态,等到任务的完成或者被拒绝)状态,此时操作未完成,所以它也是未处理的;一旦异步操作执行结束,promise 就会进入以下两种状态中的一种:Resolved 又称 fulfilled(任务执行完成并且成功的状态);Rejected(任务执行完成并且失败的状态)。


Promise 的状态只可能从 Pending 状态转到 Resolved 状态或者 Rejected 状态,而且不能逆向转换,同时 Resolved 状态和 Rejected 状态也不能相互转换。

Then()方法

所有的 Promise 都有 then()方法,且同一个 Promise 对象可以注册多个 then 方法,它接受两个可选参数:第一个是当 Promise 的状态变为 resolved 时要调用的函数;第而个是当 Promise 的状态变为 rejected 时要调用的函数。


注意事项:如果省略这两个参数,或者提供非函数,那么将创建一个没有其他处理程序的新 Promise,只是采用 Promise 的最终状态,then 被调用。


如果省略第一个参数或提供的不是函数,创建的新 Promise 简单地采用 Promise 的完成状态,then 被调用(如果它变为完成)。


如果省略第二个参数或提供的不是函数,创建的新 Promise 简单地采用 Promise 的拒绝状态,then 被调用(如果它被拒绝)。



Then 方法返回的是一个新的 promise 对象,因此可以采用链式写法;


下面这个例子使用 then 方法依次指定了两个回调函数,第一个函数执行完,执行第二个回调函数,实现依次打印 1,2,3


catch() 方法

Promise 还有一个 catch() 方法,相当于只给其传入拒绝处理程序的 then() 方法。Promise.catch() 方法是 .then(null, rejection) 的别名,用于指定发生错误时的回调函数。



上面代码中,promise 抛出一个错误,就被 catch() 方法指定的回调函数捕获。


一般总是建议,Promise 对象后面要跟 catch() 方法,这样可以处理 Promise 内部发生的错误。Catch() 方法返回的还是一个 Promise 对象,因此后面还可以接着调用 then() 方法。

将其他对象变为 Promise 对象

Promise.resovle() 和 Promise.reject() 方法,可以将不是 Promise 对象作为参数,返回一个 Promise 对象。不同的是 Promise.resovle() 返回的是完成态的 Promise,Promise.reject() 创建已拒绝的 Promise。


Promise.resovle() 和 Promise.reject() 方法都可以接受非 Promise 的 thenable 对象作为参数。如果传入一个非 Promise 的 Thenable 对象,返回的 promise 会“跟随”这个 thenable 的对象,采用它的最终状态;否则以该值为成功状态返回 promise 对象;


有两种情形:


1.假设传入的参数没有一个 .then 方法,那么这个返回的 Promise 对象变成了 resolve 状态,其 resolve 的值就是这个对象本身。


2.假设传入的参数带有一个 then 方法(称为 thenable 对象),那么将这个对象的类型变为 Promise,其 then 方法变成 Promise.prototype.then 方法。


响应多个 Promise

Promise 有一个"静态方法"——Promise.all(注意并非是 promise.prototype),这个方法接受一个元素是 Promise 对象的数组。这个方法也返回一个 Promise 对象,如果数组中所有的 Promise 对象都 resolve 了,那么这些 resolve 的值将作为一个数组作为 Promise.al()l 这个方法的返回值的(Promise 对象)的 resolve 值,之后可以被 then 方法处理。如果数组中任意的 Promise 被 reject,那么该 reject 的值就是 Promise.al()l 方法的返回值的 reject 值。then 方法的第一个回调函数接收的 resolve 值(如上所述,是一个数组)的顺序和 Promise.all 中参数数组的顺序一致,而不是按时间顺序排序。


还有一个和 Promise.all() 相类似的方法 Promise.race(),它同样接收一个数组,只不过它只接受第一个被 resolve 的值。


Promise 的兴起,解决了在异步方法调用中,会出现回调函数一环扣一环的情况。不仅代码写起来美观,而且问题复杂的时候,阅读代码的人也容易以理解。


本文转载自 Think 体验设计公众号。


原文链接:https://mp.weixin.qq.com/s/oZ-VCAXsboTx5cph4oAMVw


2020-01-10 11:51556

评论

发布
暂无评论
发现更多内容

活动 | Mint Blockchain 赞助支持清迈 WAMOTOPIA 线下活动

NFT Research

blockchain NFT L2

武汉 Linux 爱好者线下沙龙:WHLUG 2023 收官!不容错过!

nn-30

Linux 技术交流 线下沙龙 WHLUG LUG

整体模块化区块链技术引领区块链大规模采用

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

大数据服务与低代码开发:赋能创新与效率的双剑合璧

不在线第一只蜗牛

大数据 软件开发 低代码

一周内,体育赛事直播平台开发搭建上线!

软件开发-梦幻运营部

英特尔成为openEuler社区黄金捐赠人,共建最具创新的开源社区

彭飞

JProfiler for Mac:跨平台兼容性,适用性广泛

iMac小白

SD-WAN网络的可扩展性解析

Ogcloud

网络 SD-WAN 组网

低代码助力软件开发

高端章鱼哥

软件开发 低代码 JNPF

软件测试/测试开发|GitHub怎么用,这篇文章告诉你

霍格沃兹测试开发学社

MongoDB与大数据处理:构建高性能分布式数据库

互联网工科生

mongodb 非关系型数据库

SD-WAN优化远程办公网络体验

Ogcloud

远程办公 网络 SD-WAN 组网

有道基于 Amoro Mixed Format 构建准实时湖仓实践

Amoro Community

大数据 开源 湖仓一体 有道 实时湖仓

软件测试/测试开发|最容易上手的Ubuntu虚拟机安装教程

霍格沃兹测试开发学社

浅聊PAM市场价值

尚思卓越

运维 网络安全

大模型应用产品「归一妙计」亮相,AI Agent落地广告投放场景

武凯说

人工智能 领域模型 GPT 营销自动化 全媒体广告投放代理、

简述SD-WAN组网的五大技术优势

Ogcloud

网络 网络加速 SD-WAN 组网

Beyond Compare 4 for Mac v4.4.7(28397)中文版下载

iMac小白

Pipeline 助您轻松驾驭海量数据!

观测云

数据分析 日志 pipeline

centos 7.9离线下载安装vscode,以及插件安装下载教程。

百度搜索:蓝易云

云计算 Linux centos vscode 云服务器

1688商品API在跨境电商中的应用场景

技术冰糖葫芦

API

软件测试/测试开发/人工智能丨如何通过分组 AUC 从不同的维度验证模型的能力

测试人

人工智能 软件测试

演讲回顾:半导体设计中的数字资产管理最佳实践

龙智—DevSecOps解决方案

数字资产管理

第五代英特尔至强可扩展处理器AI性能大幅提升,英特尔加注推动人工智能无处不在

E科讯

Linux系统中bashrc和profile的区别

百度搜索:蓝易云

Linux 运维 Profile 云服务器 bashrc

Java后端问题排查经验

WizInfo

如何给图数据库 NebulaGraph 新增一种数据类型,以 Binary 为例

NebulaGraph

数据库

针对海量数据的存储与访问瓶颈的解决方案

快乐非自愿限量之名

数据 数据化 仓库

面试官问我:线程锁导致的kafka客户端超时,如何解决?

华为云开发者联盟

开发 华为云 华为云开发者联盟 线程锁

大模型时代,未来所有公司都是 Data+AI 公司

Kyligence

人工智能 数据分析

软件测试/测试开发|详解selenium xpath定位

霍格沃兹测试开发学社

解决回调深渊的利器(二)_文化 & 方法_Think体验设计_InfoQ精选文章