【JavaScript】JavaScript Promises实践指南

【JavaScript】JavaScript Promises实践指南

在这里插入图片描述

你了解JavaScript中的Promises吗?这是一个很多人一开始就放弃的主题,但我会尽量让它变得尽可能简单。

1. “Promise”到底是什么?

“Promise”是异步编程中的一个基本概念,特别是在JavaScript和许多现代编程语言中。它代表一个可能尚未可用但将在未来某个时刻解决的值(或操作的结果), either successfully with a value or unsuccessfully with an error.

2. Promise的状态:

在JavaScript中,Promise可以处于以下三种状态之一:

  1. Pending(进行中): 这是Promise创建时的初始状态。它表示由Promise代表的异步操作尚未完成,结果(履行或拒绝)不可用。Promises从这种状态开始,然后过渡到其他状态之一。
  2. Fulfilled(履行): 这个状态表示异步操作成功完成。当Promise过渡到履行状态时,意味着操作已成功完成,结果(值或数据)可用。您可以使用.then()方法访问解决的值。
  3. Rejected(拒绝): 这个状态表示异步操作失败。当Promise过渡到拒绝状态时,意味着操作过程中发生了错误或异常。您可以使用.catch()方法或.then()方法的第二个参数访问拒绝的原因(错误对象或消息)并处理它。

以下是Promise状态和转换的直观表示:

初始状态:         进行中/           \   
履行状态:       履行          拒绝(结果可用)    (发生错误)

Promises的设计旨在提供一种结构化的方式来处理异步操作,允许您分别处理成功和失败情况。您可以使用.then()指定Promise履行时要做的事情,使用.catch()处理Promise拒绝时的错误。这使异步代码比基于回调的方法更易于管理和阅读。

3. 如何构建一个Promise

在JavaScript中构建Promise,可以使用Promise构造函数,它接受一个单一函数作为参数。这个函数被称为执行器函数,它有两个参数:resolverejectresolve函数用于用值履行Promise,reject函数用于用错误拒绝Promise。

以下是创建Promise的基本结构:

const myPromise = new Promise((resolve, reject) => {// 异步或耗时操作在这里进行// 通常,您会执行一些异步任务,比如获取数据或读取文件// 如果操作成功,调用resolve并传入结果// resolve(result);// 如果发生错误,调用reject并传入错误对象或消息// reject(error);
});

以下是一个更具体的示例,使用setTimeout模拟延迟的异步操作,并在一定时间后解决Promise:

const delay = (milliseconds) => {return new Promise((resolve, reject) => {setTimeout(() => {resolve(`${milliseconds}毫秒后解决`);}, milliseconds);});
};// 使用:
delay(2000) // 等待2秒.then((result) => {console.log(result); // 在2000毫秒后解决}).catch((error) => {console.error(error);});

在这个示例中:

  1. 我们定义了一个返回Promise的函数delay。在Promise构造函数内部,我们使用setTimeout模拟异步延迟。
  2. 如果异步操作成功(即setTimeout完成),我们调用resolve并传入结果。
  3. 如果操作过程中发生错误,我们可以调用reject并传入错误对象或消息。
  4. 我们使用.then()指定Promise履行(解决)时要做的事情,使用.catch()处理可能发生的任何错误。

这是一个简单的示例,但在实践中,您会用真实的异步操作(如发起API请求或读取文件)替换setTimeout。Promises提供了一种结构化的方式来处理异步代码,使其更易于阅读和维护。

3.1. Promise解决时返回值

在JavaScript Promises中,您可以通过在Promise的执行器函数内将解决的值作为参数提供给resolve函数来在Promise解决时返回值。以下是操作方法:

const myPromise = new Promise((resolve, reject) => {// 模拟成功的异步操作setTimeout(() => {const result = '这是解决的值';resolve(result); // 用结果解决Promise}, 2000);
});// 使用Promise来访问解决的值
myPromise.then((result) => {console.log('解决:', result); // 解决: 这是解决的值}).catch((error) => {console.error('错误:', error);});

在这个例子中:

  1. 在Promise的执行器函数内部,我们使用setTimeout模拟异步操作。
  2. 当异步操作成功完成时,我们调用resolve(result)并传入期望的解决值(在这个例子中是'这是解决的值')。
  3. 当你使用.then()来处理Promise的解决时,解决的值作为参数传递给回调函数。你可以在那个回调函数内访问和使用解决的值。

result变量包含解决的值,你可以在.then()回调中根据需要使用它。

这种模式允许你以结构化和清晰的方式处理异步操作的结果。解决的值可以是任何数据类型,包括字符串、数字、对象,甚至是其他Promise。

3.2. Promise被拒绝时返回错误

在JavaScript Promises中,你可以通过在Promise的执行器函数内将错误消息或错误对象作为参数提供给reject函数来在Promise被拒绝时返回错误。以下是操作方法:

const myPromise = new Promise((resolve, reject) => {// 模拟失败的异步操作setTimeout(() => {const errorMessage = '这是错误消息';reject(errorMessage); // 用错误消息拒绝Promise}, 2000);
});// 使用Promise来处理拒绝和错误
myPromise.then((result) => {console.log('解决:', result);}).catch((error) => {console.error('错误:', error); // 错误: 这是错误消息});

在这个例子中:

  1. 在Promise的执行器函数内部,我们使用setTimeout模拟失败的异步操作。
  2. 当异步操作遇到错误时,我们调用reject(errorMessage)并传入期望的错误消息(在这个例子中是'这是错误消息')。
  3. 当你使用.catch()来处理Promise的拒绝时,拒绝的错误作为参数传递给回调函数。你可以在那个回调函数内访问和使用错误消息或错误对象。

error变量包含拒绝的错误,你可以根据需要处理和记录它,或执行任何其他错误处理任务。

这种模式允许你使用Promises优雅地处理可能在异步操作中发生的错误。拒绝的值可以是错误消息字符串、错误对象,或任何代表拒绝原因的其他值。

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

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

相关文章

计算机视觉总结

以下是针对上述问题的详细解答,并结合代码示例进行说明: 1. 改进YOLOv5人脸检测模块,复杂光照场景准确率从98.2%提升至99.5% 优化具体过程: 光照补偿:在数据预处理阶段,采用自适应光照补偿算法,对图像进行实时增强,以减少光照变化对人脸检测的影响。数据增强:在训练…

ExpTimerApcRoutine函数分析之作用是ActiveTimerListHead里面移除定时器_etimer

第一部分: VOID ExpTimerApcRoutine ( IN PKAPC Apc, IN PKNORMAL_ROUTINE *NormalRoutine, IN PVOID *NormalContext, IN PVOID *SystemArgument1, IN PVOID *SystemArgument2 ) /* Routine Description: This function is the special …

算法分析与设计 专题三

目录 一、实验目的 二、实验内容 三、问题分析与求解 四、AC源代码、截图 五、实验小结 一、实验目的 1、了解贪心算法的分析过程,学会用贪心算法解决一些具体的问题。 2、了解广度优先算法和深度优先算法。 二、实验内容 1992 当然,我们的收藏中…

1688商品详情接口:深度解析与应用实践

在电商领域,1688作为中国领先的B2B平台,拥有海量的商品信息。对于开发者、商家和数据分析师来说,获取1688商品的详细信息是实现数据分析、竞品研究、自动化管理和精准营销的重要手段。本文将详细介绍1688商品详情接口的使用方法、技术细节以及…

每日算法-250328

记录今天学习和解决的LeetCode算法题。 92. 反转链表 II 题目 思路 本题要求反转链表中从 left 到 right 位置的节点。我们可以采用 头插法 的思路来反转指定区间的链表。 具体来说,我们首先定位到 left 位置节点的前一个节点 prev。然后,从 left 位置…

C语言中的位域:节省内存的标志位管理技术

位域(Bit-field) 是 C 语言中的一种特性,允许在结构体(struct)中定义占用特定位数的成员变量。通过位域,可以更精细地控制内存的使用,尤其是在需要存储多个布尔值或小范围整数时,可以…

【AI编程学习之Python】第一天:Python的介绍

Python介绍 简介 Python是一种解释型、面向对象的语言。由吉多范罗苏姆(Guido van Rossum)于1989年发明,1991年正式公布。官网:www.python.org Python单词是"大蟒蛇”的意思。但是龟叔不是喜欢蟒蛇才起这个名字,而是正在追剧:英国电视喜剧片《蒙提派森的飞行马戏团》(Mo…

【openstack系列】虚拟化技术

OpenStack 是一个开源的云计算管理平台,它本身并不直接提供虚拟化技术,而是通过集成不同的虚拟化解决方案来管理和编排计算、存储和网络资源。OpenStack 的核心优势在于其灵活性和可扩展性,支持多种虚拟化技术(Hypervisor),使企业可以根据需求选择合适的底层虚拟化方案。…

保姆级教程:Vue3 + Django + MySQL 前后端联调(PyCharm+VSCode版)

一、环境准备与验证 这里为减少篇幅,默认大家都安装好了这些软件。不会下载安装的,教程也很多,这里不再做赘述。话不多说,咱们开始: 1. 安装验证 确保已安装以下软件并验证版本: # 验证Node.js node -v…

Spring Data审计利器:@LastModifiedDate详解!!!

🕒 Spring Data审计利器:LastModifiedDate详解🔥 🌟 简介 在数据驱动的应用中,记录数据的最后修改时间是常见需求。Spring Data的LastModifiedDate注解让这一过程自动化成为可能!本篇带你掌握它的核心用法…

洛谷题单1-P1001 A+B Problem-python-流程图重构

题目描述 输入两个整数 a,b,输出它们的和(∣a∣,∣b∣≤109)。 输入格式 两个以空格分开的整数。 输出格式 一个整数。 输入输出样例 输入 20 30输出 50方式-print class Solution:staticmethoddef oi_input():"""从…

CCF CSP 第33次(2024.03)(2_相似度计算_C++)(字符串中字母大小写转换+哈希集合)

CCF CSP 第33次(2024.03)(2_相似度计算_C) 题目背景:题目描述:输入格式:输出格式:样例1输入:样例1输出:样例1解释:样例2输入:样例2输出…

Windows .gitignore文件不生效的情况排查

概述 今天下班在家里捣腾自己的代码,在配置.gitignore文件忽略部分文件的时候,发现死活不生效 问题根源 经过一通分析和排查才发现,是.gitignore文件的编码错了,刚开始还没注意到,因为是在Windows下开发&#xff0c…

Uniapp自定义TabBar组件全封装实践与疑难问题解决方案

前言 在当前公司小程序项目中,我们遇到了一个具有挑战性的需求:根据不同用户身份动态展示差异化的底部导航栏(TabBar) 。这种多角色场景下的UI适配需求,在提升用户体验和实现精细化运营方面具有重要意义。 在技术调研…

四川省汽车加气站操作工备考题库及答案分享

1.按压力容器的设计压力分为( )个压力等级。 A. 三 B. 四 C. 五 D. 六 答案:B。解析:按压力容器的设计压力分为低压、中压、高压、超高压四个压力等级。 2.缓冲罐的安装位置在天然气压缩机( )。 A. 出口处 …

2025年- G27-Lc101-542. 01 矩阵--java版

1.题目描述 2.思路 总结:用广度优先搜索,首先要确定0的位置,不为0的位置,我们要更新的它的值,只能往上下左右寻找跟它最近的0的位置。 解题思路 我们用 BFS(广度优先搜索)求解,因为 …

CANopen基本理论

目录 一、CANopen简介 二、OD对象字典 2.1 OD对象字典简介 2.2 CANopen预定义连接集 三、PDO过程数据对象 四、SDO过程数据对象 五、特殊协议 5.1 同步协议 5.2 时间戳协议 5.3 紧急报文协议 六、NMT网络管理 6.1 NMT节点状态 6.2 NMT节点上线报文 6.3 NMT心跳报…

【Zookeeper搭建】Zookeeper分布式集群搭建完整指南

Zookeeper分布式集群搭建 (一)克隆前准备工作 一、时钟同步 步骤: 1、输入date命令可以查看当前系统时间,可以看到此时系统时间为PDT(部分机器或许为EST),并非中国标准时间。我们在中国地区…

MVC基础概念及相应代码示例

(旧的)代码实现方法 一个功能模块的代码逻辑(显示处理,数据处理,逻辑判定)都写在一起(耦合) (新的)代码MVC分层实现方法 显示部分实现(View视图) 数据处理实…

nginx优化(持续更新!!!)

1.调整文件描述符 # 查看当前系统文件描述符限制 ulimit -n# 永久修改文件描述符限制 # 编辑 /etc/security/limits.conf 文件,添加以下内容 * soft nofile 65535 * hard nofile 65535# 编辑 /etc/sysctl.conf 文件,添加以下内容 fs.file-max 655352.调…