当前位置: 首页 > news >正文

从0开始学习JavaScript--JavaScript使用Promise

JavaScript中的异步编程一直是开发中的重要话题。传统的回调函数带来了回调地狱和代码可读性的问题。为了解决这些问题,ES6引入了Promise,一种更现代、更灵活的异步编程解决方案。本文将深入探讨JavaScript中如何使用Promise,通过丰富的示例代码演示Promise的基本概念、链式调用、错误处理等方面的用法,帮助大家更全面地理解和应用Promise。

1. Promise的基本概念

Promise是一个表示异步操作最终完成或失败的对象。它是ES6中新增的一个构造函数,具有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)。

// 示例:Promise的基本概念
let myPromise = new Promise((resolve, reject) => {// 异步操作let isSuccess = true;if (isSuccess) {resolve("Operation successful");} else {reject("Operation failed");}
});myPromise.then((result) => {console.log(result); // 输出:Operation successful}).catch((error) => {console.error(error); // 输出:Operation failed});

在这个例子中,创建了一个简单的Promise实例,根据异步操作的结果调用resolvereject。然后通过.then().catch()处理成功和失败的情况。

2. 链式调用

Promise的优势之一是支持链式调用,通过.then()方法将多个异步操作连接在一起,增强了代码的可读性。

// 示例:链式调用
function fetchData() {return new Promise((resolve) => {setTimeout(() => {resolve({ data: "Some data" });}, 1000);});
}fetchData().then((result) => {console.log(result); // 输出:{ data: 'Some data' }return result.data;}).then((data) => {console.log(`Processed data: ${data}`); // 输出:Processed data: Some data});

在这个例子中,fetchData()返回一个Promise实例,通过.then()方法处理异步操作的结果,并将结果传递给下一个.then()

3. Promise.all()

Promise.all()接收一个包含多个Promise的可迭代对象,并在所有Promise都成功时才成功,任意一个Promise失败则整体失败。

// 示例:Promise.all()
let promise1 = Promise.resolve("Promise 1");
let promise2 = new Promise((resolve) => setTimeout(() => resolve("Promise 2"), 2000));
let promise3 = fetch("https://api.example.com/data");Promise.all([promise1, promise2, promise3]).then((results) => {console.log(results); // 输出:['Promise 1', 'Promise 2', Response]}).catch((error) => {console.error(error); // 输出:如果有任意一个Promise失败});

在这个例子中,Promise.all()等待所有传入的Promise完成,然后返回一个包含所有结果的新Promise。

4. Promise.race()

Promise.race()同样接收一个包含多个Promise的可迭代对象,但只要有一个Promise完成或失败,整体就完成或失败。

// 示例:Promise.race()
let racePromise1 = new Promise((resolve) => setTimeout(() => resolve("Race Promise 1"), 1000));
let racePromise2 = new Promise((resolve) => setTimeout(() => resolve("Race Promise 2"), 2000));Promise.race([racePromise1, racePromise2]).then((result) => {console.log(result); // 输出:Race Promise 1}).catch((error) => {console.error(error); // 不会执行});

在这个例子中,Promise.race()返回一个新Promise,它会在第一个Promise完成或失败时完成或失败。

5. 错误处理

Promise通过.catch()方法提供了一种集中处理错误的方式,使得错误处理更为清晰。

// 示例:错误处理
function throwError() {return new Promise((resolve, reject) => {reject("An error occurred");});
}throwError().then((result) => {console.log(result); // 不会执行}).catch((error) => {console.error(error); // 输出:An error occurred});

在这个例子中,throwError()返回一个Promise,并通过.catch()捕获了错误。

6. async/await与Promise

ES2017引入了asyncawait关键字,使得异步代码更像同步代码,更容易理解和维护。

// 示例:async/await与Promise
function fetchData() {return new Promise((resolve) => {setTimeout(() => {resolve("Async data");}, 1000);});
}async function fetchDataAsync() {try {let result = await fetchData();console.log(result); // 输出:Async data} catch (error) {console.error(error); // 不会执行}
}fetchDataAsync();

在这个例子中,fetchDataAsync()使用async标记,内部使用await等待Promise完成,使得异步代码看起来更加同步。

总结

Promise是JavaScript中处理异步编程的一种现代解决方案,通过简洁的语法和丰富的方法提供了更好的编程体验。通过本文的介绍,读者应该对Promise的基本概念、链式调用、Promise.all()Promise.race()、错误处理以及与async/await的结合有了更全面的了解。

未来,随着JavaScript语言的发展,异步编程的解决方案可能会进一步演进,但Promise作为当前主流的解决方案,将在很长一段时间内继续发挥着重要作用。

相关文章:

从0开始学习JavaScript--JavaScript使用Promise

JavaScript中的异步编程一直是开发中的重要话题。传统的回调函数带来了回调地狱和代码可读性的问题。为了解决这些问题,ES6引入了Promise,一种更现代、更灵活的异步编程解决方案。本文将深入探讨JavaScript中如何使用Promise,通过丰富的示例代…...

使用契约的链上限价订单

我们开发了链上限价订单。 它基于一种称为契约的智能合约,只有在花费输出的交易满足特定条件时才可以花费输出。 为了演示其工作原理,我们实施了以比特币支付的 Ordinals 代币买卖限价订单,无需托管人。 它可以运行在任何比特币协议链上&…...

Iceberg学习笔记(1)—— 基础知识

Iceberg是一个面向海量数据分析场景的开放表格式(Table Format),其设计的目的是解决数据存储和计算引擎之间的适配的问题 表格式(Table Format)可以理解为元数据以及数据文件的一种组织方式,处于计算框架&…...

springboot中动态api如何设置

1.不需要编写controller 等mvc层,通过接口动态生成api。 这个问题,其实很好解决,以前编写接口,是要写controller,需要有 RestController RequestMapping("/test1") public class xxxController{ ApiOperat…...

Java —— 抽象类和接口

目录 1. 抽象类 1.1 抽象类概念 1.2 抽象类语法与特性 1.3 抽象类的作用 2. 接口 2.1 接口的概念 2.2 接口的语法规则与特性 2.3 实现多个接口(解决多继承的问题) 2.4 接口间的继承 2.5 抽象类和接口的区别 2.6 接口的使用实例 2.7 Clonable 接口和深拷贝 2.7.1 Cloneable接口 …...

数字IC前端学习笔记:异步复位,同步释放

相关阅读 数字IC前端https://blog.csdn.net/weixin_45791458/category_12173698.html?spm1001.2014.3001.5482 异步复位 异步复位是一种常见的复位方式,可以使电路进入一个可知的状态。但是不正确地使用异步复位会导致出现意想不到的错误,复位释放便是…...

Linux内核移植之网络驱动更改说明一

一. 简介 本文学习 NXP官方Linux内核移植网络驱动的更改。 为了方便后面 Linux驱动的开发调试,所以,必须要把网络驱动调试好。 如果在做 Linux驱动开发时,写了一个 app或驱动,就需要将系统全部文件(即 uboot&#…...

邮件|gitpushgithub报错|Lombok注解

基于 Spring Boot 搭建一个定时发送邮件的项目可以按照以下步骤进行: 创建一个新的 Spring Boot 项目,并添加所需的依赖。在 pom.xml 文件中添加以下依赖项(根据你的需要进行调整): xml org.springframework.boot sp…...

【前端知识】Node——events模块的相关方法

一、events模块的常用方法 // 事件总线 const EventsEmitter require(events);const emitter new EventsEmitter();function HLog(msg){console.log(msg); }// 监听 emitter.on(hlog, HLog);setTimeout(() > {// 触发,打印emitter.emit(hlog, hello emitter!)…...

广州华锐互动VRAR | VR课件内容编辑器解决院校实践教学难题

VR课件内容编辑器由VR制作公司广州华锐互动开发,是一款专为虚拟现实教育领域设计的应用,它能够将传统的教学内容转化为沉浸式的三维体验。通过这款软件,教师可以轻松创建和编辑各种虚拟场景、模型和动画,以更生动、直观的方式展示…...

Wireshark抓包:理解TCP三次握手和四次挥手过程

TCP是一种面向连接、端到端可靠的协议,它被设计用于在互联网上传输数据和确保成功传递数据和消息。本节来介绍一下TCP中的三次握手和四次挥手。 文章目录 1 TCP头部格式2 wireshark抓包分析2.1 SEQ和ACK2.2 三次握手2.3 四次挥手 3 程序 1 TCP头部格式 TCP头部占据…...

网络工程师-HCIA网课视频学习

这里是速成的,只积累下,自己未曾学习到的东西。通过书本补充知识点。 视频:hcia17-链路聚合_哔哩哔哩_bilibili hcia16-路由高级特性: hcia17-链路聚合: 由于如果根据视频来学习的话,感觉视频的总结并不…...

【每日刷题——语音信号篇】

思考与练习 练习2.1 语音信号在产生的过程中,以及被感知的过程中,分别要经过人体的哪些器官? 1.产生过程: 肺部空气 → \rightarrow →冲击声带 → \rightarrow →通过声道(可以调节) → \rightarrow →…...

Linux进程通信——IPC、管道、FIFO的引入

进程间的通信——IPC 进程间通信 (IPC,InterProcess Communication) 是指在不同进程之间传播或交换信息。 IPC的方式通常有管道 (包括无名管道和命名管道) 、消息队列、信号量、共享存储、Socket、Streams等。其中 Socket和Streams支持不同主机上的两个进程IPC。 …...

数理统计的基本概念(一)

文章目录 总体、样本与统计量总体及其分布样本及其分布统计量统计量概念样本矩顺序统计量及其分布样本中位数与样本极差经验分布函数 参考文献 总体、样本与统计量 总体及其分布 在数理统计中,称所研究的对象的全体为总体,总体中的元素称为个体。若总体…...

clickhouse分布式之弹性扩缩容的故事

现状 社区不支持喔,以后也不会有了。曾经尝试过,难道是是太难了,无法实现吗?因为他们企业版支持了,可能是利益相关吧,谁知道呢,毕竟开源也要赚钱,谁乐意一直付出没有回报呢。 社区…...

数据结构--串的基本概念

目录 串的基本概念 串的定义 串与线性表对比 ​串的基本操作​ 串的比较 字符集编码 乱码问题​编辑 总结 ​串的存储结构 ​串的顺序存储​编辑 串的链式存储 串的基本操作 1、求字串 2、比较 3、定位操作 总结 串的基本概念 串的定义 串与线性表对比 串的…...

音视频流媒体之 IJKPlayer FFmpeg Android 编译

FIJK dockerfile 编译环境 FROM --platformlinux/amd64 ubuntu:18.04RUN apt-get update && apt-get install -y \wget \unzip \git \gcc \g \make \python \yasm \pkg-config \protobuf-compiler \sudoRUN apt-get install -y openjdk-8-jdkENV ANDROID_HOME…...

记录一次较为完整的Jenkins发布流程

文章目录 1. Jenkins安装1.1 Jenkins Docker安装1.2 Jenkins apt-get install安装 2. 关联github/gitee服务与webhook2.1 配置ssh2.2 Jenkins关联2.3 WebHook 3. 前后端关联发布 1. Jenkins安装 1.1 Jenkins Docker安装 Docker很好,但是我没有玩明白如何使用Docke…...

Virtual安装centos后,xshell连接centos 测试及遇到的坑

首先来一张官方的图--各种网络模式对应的连接状况: 1. 网络使用Host-Only模式动态分配IP,点确定后,centos 上运行 system restart network ,使用ifconfig查看新的ip,XShell可以直接连上centos, 但是由于使用…...

openclaw官网入口中文版_一键1分钟免费使用小龙虾AI!

好的,这是为您撰写的文章: OpenClaw官网入口中文版_一键1分钟免费使用小龙虾AI! 在当今人工智能技术蓬勃发展的时代,便捷、高效的AI工具正逐渐成为我们工作和学习的得力助手。今天,就让我们一起了解一个新兴的AI平台—…...

多模态大语言模型如何优化多机器人系统协同

1. 多模态大语言模型驱动的多机器人系统架构设计多模态大语言模型(MLLM)正在彻底改变多机器人系统的协同工作方式。这种新型架构通过将自然语言理解、多模态感知和分布式决策能力深度融合,使机器人团队能够像人类工作组一样理解复杂指令并自主…...

别再只会用Bridge了!从KVM网络配置到Open vSwitch实战,聊聊虚拟交换机的那些‘坑’

从传统桥接到Open vSwitch:虚拟网络进阶实战指南 在虚拟化技术普及的今天,网络配置往往成为制约整体性能的关键瓶颈。许多运维工程师在初期使用KVM默认的桥接或NAT网络时,能够满足基本需求,但随着业务规模扩大,传统方案…...

NVIDIA Profile Inspector深度指南:解锁显卡隐藏性能的完整教程

NVIDIA Profile Inspector深度指南:解锁显卡隐藏性能的完整教程 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 还在为游戏画面撕裂、输入延迟高、帧率不稳定而烦恼吗?NVIDIA Pr…...

使用 Taotoken 为 Ubuntu 上的 Node.js 应用提供稳定的大模型 API 服务

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 使用 Taotoken 为 Ubuntu 上的 Node.js 应用提供稳定的大模型 API 服务 在 Ubuntu 服务器上部署 Node.js 应用,并为其集…...

代码与图形的双向桥梁:在Draw.io中实现Mermaid图表工作流

代码与图形的双向桥梁:在Draw.io中实现Mermaid图表工作流 【免费下载链接】drawio_mermaid_plugin Mermaid plugin for drawio desktop 项目地址: https://gitcode.com/gh_mirrors/dr/drawio_mermaid_plugin 在技术文档和系统设计的日常工作中,开…...

跟着 MDN 学 HTML day_34:(深入XML 中的 CDATASection 接口)

在 Web 开发的学习旅程中,我们大部分时间都在与 HTML 打交道。然而,当涉及到数据存储、配置文件或 RSS 订阅时,XML 依然扮演着不可或缺的角色。今天,我们将聚焦于 XML 世界中一个看似不起眼但在特定场景下极其有用的接口&#xff…...

蝾螈机器人多自由度控制与强化学习实践

1. 蝾螈机器人全身控制的技术挑战蝾螈作为自然界典型的两栖动物,其运动模式具有独特的生物力学特性。传统机器人控制方法在面对这种多自由度系统时面临诸多挑战。我曾在实验室参与过类似的多关节机器人控制项目,深刻体会到协调十几个关节运动的复杂性。1…...

从F1赛车到无人机:雷达测距测速公式在现实世界中的5个酷应用

从F1赛车到无人机:雷达测距测速公式在现实世界中的5个酷应用 当F1赛车以300公里时速呼啸而过时,车手如何精确判断与前车的安全距离?当无人机在复杂环境中自主飞行时,又是怎样避开突然出现的障碍物?这些看似科幻的场景背…...

如何实现微信聊天记录的永久保存与智能分析?WeChatMsg完整指南

如何实现微信聊天记录的永久保存与智能分析?WeChatMsg完整指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/…...