8个关于 Promise.then 和 Promise.catch 的面试题,一定要掌握

news2024/11/26 0:32:09

前面,我们要讨论了 Promise 在异步编程中的执行,错过的朋友可以直接点击《10 个 JavaScript Promise 的面试题》这篇文章进行查看。

在今天的文章中,我们将讨论这些核心 API 用于 Promise 对象的用法。

这里我提供了10个代码片段,你需要看一看这些程序的执行结果。

你准备好了吗?我们要开始了!

01、

const promise = new Promise((resolve, reject) => {  resolve("success1");  reject("fail");  resolve("success2");});
promise.then(res => {    console.log("then: ", res);  }).catch(err => {    console.log("catch: ", err);  })

此代码段的输出是什么?

分析

我们知道 Promise 可能是以下三种状态之一:

  • 待定:初始状态,既不履行也不拒绝。

  • 已完成:表示操作已成功完成。

  • 拒绝:表示操作失败。

状态只能从待处理变为已完成,或从待处理变为已拒绝。

这种变化是不可逆的。它不能从已完成变为待处理,也不能从拒绝变为待处理。同时,完成不能变成拒绝,拒绝也不能变成完成。

所以在上面的代码中,只有 resolve('success1') 是一个有效的操作。最后两个无效。

结果

这是嵌入演示:

const promise = new Promise((resolve, reject) => {  resolve("success1");  reject("fail");  resolve("success2");});
promise.then(res => {    console.log("then: ", res);  }).catch(err => {    console.log("catch: ", err);  });

02、

const promise = new Promise((resolve, reject) => {  reject("fail");  resolve("success2");});promise.then(res => {    console.log("then1: ", res);  }).then(res => {    console.log("then2: ", res);  }).catch(err => {    console.log("catch: ", err);  }).then(res => {    console.log("then3: ", res);  })

此代码段的输出是什么?

分析

首先,无论catch方法放在哪里,都能捕捉到上层没有捕捉到的错误。

同时需要注意的是,catch 方法也会返回一个新的 Promise 对象,导致后面的 then 方法也被执行。

结果

所以输出是:

catch:  failthen3:  undefined

03、

Promise.resolve(1)  .then(res => {    console.log(res);    return 2;  })  .catch(err => {    return 3;  })  .then(res => {    console.log(res);  })  .then(res => {    console.log(res);  });

此代码段的输出是什么?

分析

每个 .then() 方法的返回值都是一个新的 Promise。即使代码说 return 2,实际执行的是 return Promise.resolve(2) 。

结果

所以输出是:

12undefined

04、

Promise.reject(1)  .then(res => {    console.log(res);    return 2;  })  .catch(err => {    return 3;  })  .then(res => {    console.log(res);  })  .then(res => {    console.log(res);  });

此代码段的输出是什么?

分析

这个挑战和上一个几乎一样,只是从 Promise.resolve 变成了 Promise.reject。所以执行流程会有一些变化。

结果

所以输出是:

3undefined

05、

const promise = new Promise((resolve, reject) => {    resolve(1)})
promise.then(res => {  console.log('first then: ', res)  return 2})
promise.then(res => {  console.log('second then: ', res)  return 3})
promise.then(res => {  console.log('third then: ', res)})

此代码段的输出是什么?

分析

记住一条铁律:一旦确定了 Promise 的状态,就无法更改。

同样在这个题中,那些 .then() 不是链式调用,它们都是对 promise 对象的调用。

结果

所以输出是:

111

06、

Promise.resolve().then(() => {  return new Error('error!!!')}).then(res => {  console.log("then: ", res)}).catch(err => {  console.log("catch: ", err)})

此代码段的输出是什么?

分析

小心这个挑战。

new Error() 是一个普通的 JavaScript 对象,return 是一个普通的 JavaScript 关键字,所以这段代码会正常工作,不会抛出异常。

它将返回一个已完成状态且值为 new Error('error!!!') 的对象。

所以输出是:

then:  Error: error!!!

当然,如果你想抛出错误,你可以使用以下任一方法:

return Promise.reject(new Error('error!!!'));// orthrow new Error('error!!!')

07、

const promise = Promise.resolve().then(() => {  return promise;})
promise.catch(console.err)

此代码段的输出是什么?

分析

.then 或 .catch 返回的值不能是 Promise 本身,否则会导致死循环。

所以代码会抛出异常:

TypeError: Chaining cycle detected for promise #<Promise>}

08、

Promise.resolve(1)  .then(2)  .then(Promise.resolve(3))  .then(console.log)

此代码段的输出是什么?

分析

这个问题看似简单,但其实大部分人的答案都是错误的。

  • .then 或 .catch 的参数应该是一个函数。

  • 如果参数不是函数,则此 .then 或 .catch 将被忽略。

总结

以上就是我今天跟你分享的全部内容,希望这个内容对你有所帮助,最后,感谢你的阅读。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/52783.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SequoiaDB湖仓一体分布式数据库2022.11月刊

本月看点速览 产品能力再获认可&#xff0c;入围多个榜单、报告 ‍精彩亮相2022沙丘大会湖仓一体专场 实力吸睛&#xff0c;获多家权威媒体关注与报道 生态圈不断扩大&#xff0c;与6家合作伙伴完成互认证 青杉计划2023进行中&#xff0c;一起攀登更高的“杉” 产品能力再获…

WPF 3D 摄像机LookDirection属性研究

像前文一样画一个三角形&#xff1b; 摄像机的位置是(-2,2,2)&#xff1b; 坐标系是这样的&#xff0c;x、y轴是在屏幕上&#xff0c;X轴正向向右&#xff0c;Y轴正向向上&#xff1b;Z轴是垂直于屏幕&#xff0c;从屏幕出来往人的方向为正向&#xff0c;往屏幕里边去是-Z&…

01-06-Hbase基础定义

Hbase定义&#xff1a; Hbase是一种分布式&#xff0c;可扩展&#xff0c;支持海量数据存储的NoSQL数据库。HBase是一个分布式的、面向列的开源数据库。HBase是Apache的Hadoop项目的子项目。HBase不同于一般的关系数据库&#xff0c;它是一个适合于非结构化数据存储的数据库。…

[附源码]Python计算机毕业设计SSM垃圾分类网站的设计与实现(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

得一微冲刺科创板上市:拟募资约12亿元,2021年营收同比增长260%

撰稿|汤汤 来源|贝多财经 近日&#xff0c;得一微电子股份有限公司&#xff08;下称“得一微”&#xff09;在上海证券交易所科创板递交招股书&#xff08;申报稿&#xff09;。本次冲刺科创板上市&#xff0c;得一微拟公开发行不超过2354万股股份&#xff0c;计划募资12.24亿…

两直线垂直,斜率乘积为-1的证明

老早以前在学习初等函数的时候&#xff0c;线性函数中的两直线y m0x b0, y m1x b1如果垂直&#xff0c;则有结论两条直线的斜率乘积为-1即m0*m1 -1&#xff0c;以前也只是拿来用&#xff0c;没有证明过。最近在学图形学的时候&#xff0c;突然想起了这个点&#xff0c;因此…

[附源码]计算机毕业设计springboot社区人员信息管理系统设计与实现

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

UE5笔记【十一】蓝图变量BluePrint Variables

类似于在材料中将配置参数化&#xff0c;我们这里也可以将配置变量化。最后实现在对象detail细节中设置修改。 在左侧组件中找到【变量】&#xff0c;然后点击那个加号&#xff0c;添加两个变量用来控制楼梯和盒体的升降速度。 分别命名为&#xff1a;BoxSpeed和StairSpeed。然…

Java链接redis集群

1.导入依赖 <dependencies><!-- 1、 Jedis--><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version></dependency><!-- 2、 Junit测试--><depen…

STM32f767之通用定时器

一&#xff0c;通用定时器基本介绍 二&#xff0c;配置相关项 1&#xff0c;时钟源。 一般我们选择内部时钟&#xff0c;TIM3通过APB1得到。 2&#xff0c;主从模式和触发源。 用到的比较少&#xff0c;暂时不考虑&#xff0c;选disable。 3&#xff0c;输出通道。 如果…

8年开发经验,帮你总结这帮双面HR们

对于广大开发工程师来说&#xff0c;你觉得天天看得见的那个hr小姐姐是什么形象&#xff1f; 读完本文&#xff0c;或许你会有一个不一样的认识&#xff0c;这个职业注定这些人有两面性 1、 百万人群中取你简历 从你还没进公司&#xff0c;还在面试阶段&#xff0c;就是hr跑前跑…

计算机网络全篇知识学习打卡

哈工大计算机网络学习打卡 1. 什么是计算机网络&#xff1f; 概念&#xff1a;通信技术与计算机技术紧密结合的产物&#xff0c;计算机网络就是一种特殊的通信网络。只不过计算机网络发送出来的信息是数据化信息。 定义&#xff1a;计算机网络就是互连的&#xff0c;自治的计…

TypeScript(TS)基础内容详细介绍

目录 一、TypeScript概念 二、TypeScript特点 三、开发环境配置 四、初识ts 五、TypeScript类型声明 1、any&#xff1a; 2、number数字类型 3 string字符串类型 4 boolean布尔类型 表示逻辑值&#xff1a;true 和 false。 5 数组类型 6 元组类型 7 enum枚举类型…

[附源码]Python计算机毕业设计SSM篮球馆预约小程序(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

MySQL介绍与安装(超详细)

数据库介绍 数据库(database)简称DB&#xff0c;实际上就是一个文件集合&#xff0c;是一个存储数据的仓库&#xff0c;本质就是一个文件系统&#xff0c;数据库是按照特定的格式把数据存储起来&#xff0c;用户可以对存储的数据进行增删改查等操作。 数据库存储数据特点 ●…

零拷贝原理与实现

1.传统拷贝 FileInputStream、FileOutputStream read&#xff1a;将数据从磁盘读取到内核态缓冲区&#xff0c;再从内核态缓冲区拷贝到用户缓冲区 write&#xff1a;将数据从用户缓冲区写入到socket缓冲区&#xff0c;再从socket缓冲区写入到网卡设备 内核空间&#xff1a;…

Error: [mobx-miniprogram] no store specified (小程序全局数据共享bug)

话不多说&#xff0c;上bug&#xff01;&#xff01;&#xff01; 这个错误提示引入的store文件没有被指定&#xff0c;但是看了一下以为是后面的路径没引对&#xff0c;就重新引入还是不行&#xff0c;页面效果渲染不出来&#xff0c;然后查文档也没遇到类似的问题&#xff0…

【JSP】JSTL汇总——源码解析

JSTL什么是JSTL使用JSTL的步骤JSTL标签的原理分析标签源码看核心标签库中的forEach标签主标签库常用标签forEach标签begin、end、step属性stuStatus属性if标签test属性var和scopechoose和when标签什么是JSTL JSTL全称为 Java Standard Tag Library&#xff08;Java标准标签库&…

[附源码]计算机毕业设计springboot区域医疗服务监管可视化系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

C++读写Excel有许多开源库

1、OpenXLSX GitHub - troldal/OpenXLSX: A C library for reading, writing, creating and modifying Microsoft Excel (.xlsx) files. 依赖于第三库&#xff1a; PugiXMLZippy (C wrapper around miniz)Boost.Nowide (for opening files with non-ASCII names on Windows)…