从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作为当前主流的解决方案,将在很长一段时间内继续发挥着重要作用。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++二分算法:找到最接近目标值的函数值

本文涉及的基础知识点 二分查找算法合集 题目 Winston 构造了一个如上所示的函数 func 。他有一个整数数组 arr 和一个整数 target ,他想找到让 |func(arr, l, r) - target| 最小的 l 和 r 。 请你返回 |func(arr, l, r) - target| 的最小值。 请注意&#xff0c…

读像火箭科学家一样思考笔记04_第一性原理(下)

1. 来自无形规则的阻力 1.1. 无形规则 1.1.1. 僵化成规则的不必要习惯和行为 1.1.2. 不像有形的书面规则 1.1.2.1. 书面规则出现在标准操作流程中,可以修改或删除 1.1.3. 成文的规则可能会抗拒变革,但无形规则却更加顽固 1.1.4. 我们为强加在自己身…

华为---OSPF网络虚连接(Virtual Link)简介及示例配置

OSPF网络虚连接(Virtual Link)简介 为了避免区域间的环路,OSPF规定不允许直接在两个非骨干区域之间发布路由信息,只允许在一个区域内部或者在骨干区域和非骨干区域之间发布路由信息。因此,每个ABR都必须连接到骨干区域…

【计算机网络笔记】路由算法之链路状态路由算法

系列文章目录 什么是计算机网络? 什么是网络协议? 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能(1)——速率、带宽、延迟 计算机网络性能(2)…

CTF-PWN-小tips

文章目录 overflowscanfgetreadstrcpystrcat Find string in gdbgdbgdb peda Binary ServiceFind specific function offset in libc手工自动 Find /bin/sh or sh in library手动自动 Leak stack addressFork problem in gdbSecret of a mysterious section - .tlsPredictable …

手机照片误删解决方法分享

几个要点 1.检查回收站:一些情况下,我们会在删除文件时将它们移动到回收站中,查看回收站中是否有被删除的照片,这样可以直接恢复文件。 2.使用手机自带的恢复功能:一些手机自带照片恢复功能,可尝试在相册…

【云栖 2023】张治国:MaxCompute 架构升级及开放性解读

云布道师 本文根据 2023 云栖大会演讲实录整理而成,演讲信息如下 演讲人:张治国|阿里云智能计算平台研究员、阿里云 MaxCompute 负责人 演讲主题:MaxCompute架构升级及开放性解读 活动:2023云栖大会 MaxCompute 发展经历了三个阶…

适合您的智能手机的 7 款优秀手机数据恢复软件分享

如今,我们做什么都用手机;从拍照到录音,甚至作为 MP3 播放器,我们已经对手机变得非常依恋。这导致我们在手机上留下了很多珍贵的回忆。 不幸的是,我们有可能会丢失手机上的部分甚至全部数据。幸运的是,这不…

使用大语言模型 LLM 做文本分析

本文主要分享 传统聚类算法 LLM与嵌入算法 嵌入算法聚类 LLM的其他用法 聚类是一种无监督机器学习技术,旨在根据相似的数据点的特征将其分组在一起。使用聚类成簇,有助于解决各种问题,例如客户细分、异常检测和文本分类等。尽管传统的聚…

济南数字孪生赋能工业制造,加速推进制造业数字化转型

济南数字孪生赋能工业制造,加速推进制造业数字化转型。数字孪生是指通过数字模型对现实世界进行模拟和描述,从而实现数字化转型的技术。数字孪生技术通过利用先进传感与测量技术、实时数据融合及分析技术、虚拟现实技术和仿真技术,在数字空间…

vs code git问题:文件明明已加入忽略文件中,还是出现

vs code git问题:文件明明已加入忽略文件中,还是出现 原因: 因为之前这些文件都已经提交过,线上GIT已经存在,已存在就不能忽略, 解决办法: 先要删除这些文件提交上去,然后把这些文…

企业级固态硬盘如何稳定运行?永铭固液混合铝电解电容来帮忙

企业级 固态硬盘 永铭固液混合铝电解电容 企业级固态硬盘(SSD)主要应用于互联网、云服务、金融和电信等客户的数据中心,企业级SSD具备更快传输速度、更大单盘容量、更高使用寿命以及更高的可靠性要求。 企业级固态硬盘的运行要求—固液混合电…

STM32:OLED屏幕开发

一、OLED原理 所谓的屏幕就是由一个个小灯组成,每个小灯称之为一个像素。只要在屏幕上有选择地点亮一部分小灯,就可以显示我们想要的图案。所谓下分辨率就是屏幕上的小灯数量。常见单片机中常见的屏幕分辨率常见的就是128(列长)*64(行高)。如果每个小灯都…

沸点 | Ultipa 图数据库金融应用场景优秀案例首批入选,金融街论坛年会发布

为推进图数据库在金融行业的创新应用试点,近日,在2023金融街论坛年会“全球金融科技中心网络年会暨ZIBS北京论坛”上,北京前沿金融监管科技研究院发布了基于国际标准组织——国际关联数据基准委员会(LDBC)的《图数据库…

NX二次开发UF_CAM_ask_blank_matl_db_object 函数介绍

文章作者:里海 来源网站:里海NX二次开发3000例专栏 UF_CAM_ask_blank_matl_db_object Defined in: uf_cam.h int UF_CAM_ask_blank_matl_db_object(UF_CAM_db_object_t * db_obj ) overview 概述 This function provides the database object which …

五、程序员指南:数据平面开发套件

服务质量 (QoS) 框架 本章介绍 DPDK 服务质量 (QoS) 框架。 21.1 带有 QoS 支持的数据包流水线 下图显示了一个具有 QoS 支持的复杂数据包处理流水线的示例 表21.1:带有 QoS 支持的复杂数据包处理流水线 这个流水线可以使用可重用的 DPDK 软件库构建。在这个流…

队列的实现和OJ练习

目录 概念 队列的实现 利用结构体存放队列结构 为什么单链表不使用这种方法? 初始化队列 小提示: 队尾入队列 队头出队列 获取队头元素 获取队尾元素 获取队列中有效元素个数 检测队列是否为空 销毁队列 最终代码 循环队列 队列的OJ题 …

FFmpeg常用命令行讲解及实战一

文章目录 前言一、学习资料参考二、FFmpeg 选项1、主要选项①、主要命令选项②、举例 2、视频选项①、主要命令选项②、举例1)提取固定帧2)禁止输出视频3)指定视频的纵横比 3、音频选项①、主要命令选项②、举例 4、字幕选项①、主要命令选项…

基于混沌博弈算法优化概率神经网络PNN的分类预测 - 附代码

基于混沌博弈算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于混沌博弈算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于混沌博弈优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要:针对PNN神…

二分查找——34. 在排序数组中查找元素的第一个和最后一个位置

文章目录 1. 题目2. 算法原理2.1 暴力解法2.2 二分查找左端点查找右端点查找 3. 代码实现4. 二分模板 1. 题目 题目链接:34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode) 给你一个按照非递减顺序排列的整数数组 nums&#…