JavaScript Promise:您需要了解的基础知识

javascript promise:您需要了解的基础知识

介绍

javascript 是一种单线程编程语言,这意味着它一次只能运行一个任务。对于诸如获取数据或设置计时器之类的异步操作来说,这变得很棘手,这可能会阻塞执行流程并减慢您的应用程序的速度。

为了在不冻结线程的情况下处理这些异步任务,我们遇到了promise——一个简化异步编程的强大工具。借助 promises,您可以更有效地管理长时间运行的任务,编写更干净、更具可读性的代码,并避免可怕的“回调地狱。

在本文中,我的目标是让您熟悉 promise 是什么、它们如何工作以及它们如何简化异步编程。

什么是承诺?

想象一下您正在一家餐厅点餐。下订单后,您无需在厨房等待食物准备好。相反,您可以在厨房在后台准备餐点的同时继续交谈或享受氛围。餐厅承诺一旦食物准备好就会为您提供食物。您可以相信这个承诺,因为最终会发生以下两种情况之一:您的餐食将到达(已完成),或者厨房会通知您他们无法完成订单(已拒绝) )。

立即学习“Java免费学习笔记(深入)”;

在 javascript 中,promise 以类似的方式工作。当您要求 javascript 执行一些需要时间的操作(例如从服务器获取数据)时,它会返回一个 promise。这个promise不会立即给你结果。相反,它会告诉您:“工作完成后我会回复您。”在此期间,其余代码将继续运行。任务完成后,promise 为:

已完成(任务成功),或已拒绝(任务失败),您可以相应处理结果。

promise 在 javascript 中如何工作

promise 代表一个可能现在、将来或永远不可用的值。它具有三种状态:

待处理:任务仍在进行中,最终结果(完成或拒绝)尚未确定。已完成:任务已成功完成,结果已出。已拒绝:任务失败,有错误可处理

1. 创造一个承诺

要创建 promise,可以使用 promise 构造函数,它采用一个具有两个参数的函数(称为执行器):resolve 和reject。当 promise 满足时,将调用resolve函数,而当被拒绝时,将调用reject函数。

const mypromise = new promise((resolve, reject) => {  // simulating an asynchronous task (e.g., fetching data)  const success = true; // simulate success or failure  if (success) {    resolve("operation completed successfully!"); // fulfill the promise  } else {    reject("operation failed."); // reject the promise  }});

2. 解决和拒绝承诺

一旦创建了promise,您可以通过调用resolve或reject来决定其结果:

resolve(value):当异步操作成功完成时调用此函数。它将一个值传递给等待 promise 履行的处理程序。reject(error):当操作失败时调用该函数。它将错误消息传递给等待 promise 被拒绝的处理程序。

3. 消费承诺

创建 promise 后,下一步就是使用它。 javascript 提供了几种处理 promise 结果的方法:.then()、.catch() 和 .finally()。这些方法中的每一个都有特定的目的,并允许您有效地管理异步操作的结果。

使用 .then() 处理已解决的 promise:.then() 方法用于指定当 promise 完成时应该发生什么。它需要两个可选参数:一个用于解析值的回调,另一个用于处理拒绝。

const fetchdata = () => {  return new promise((resolve) => {    settimeout(() => {      resolve("data fetched successfully!");    }, 1000);  });};fetchdata()  .then(result => {    console.log(result); // logs: data fetched successfully!  });

使用 .catch() 处理拒绝:.catch() 方法专门用于处理 promise 执行期间发生的错误。这使其成为处理拒绝的干净方法。

const fetchwitherror = () => {  return new promise((resolve, reject) => {    settimeout(() => {      reject("error fetching data."); // simulating an error    }, 1000);  });};fetchwitherror()  .then(result => {    console.log(result);  })  .catch(error => {    console.error(error); // logs: error fetching data.  });

使用 .finally() 进行最终或清理操作:.finally() 方法允许您在 promise 解决后执行代码,无论它是被履行还是被拒绝。这对于应在成功和失败场景中运行的清理操作或任务非常有用。

fetchdata()  .then(result => {    console.log(result); // logs: data fetched successfully!  })  .catch(error => {    console.error(error); // handle error  })  .finally(() => {    console.log("promise has settled."); // logs after either success or failure  });

简而言之:

then():使用此方法处理 promise 的解析值。catch():使用此方法来处理 promise 被拒绝时的错误。finally():此方法在 promise 解决后运行代码,无论结果如何,允许清理或最终操作。

4. 承诺链

promises 最强大的功能之一是它们能够链接在一起,允许您按顺序执行多个异步操作。这意味着每个操作都要等待前一个操作完成才能执行,这在任务相互依赖时特别有用。

让我们看一下下面的例子:

const fetchUserData = () => {  return new Promise((resolve) => {    setTimeout(() => {      resolve({ userId: 1, username: "JohnDoe" });    }, 1000);  });};const fetchPosts = (userId) => {  return new Promise((resolve) => {    setTimeout(() => {      resolve(["Post 1", "Post 2", "Post 3"]); // Simulated posts    }, 1000);  });};// Chaining PromisesfetchUserData()  .then(user => {    console.log("User fetched:", user);    return fetchPosts(user.userId); // Pass userId to the next promise  })  .then(posts => {    console.log("Posts fetched:", posts);  })  .catch(error => {    console.error("Error:", error);  });

在此示例中,fetchuserdata 函数返回一个使用用户信息解析的 promise。然后,解析后的值被传递给 fetchposts 函数,该函数返回另一个 promise。如果这些 promise 中的任何一个被拒绝,错误将在最终的 .catch() 方法中捕获,从而允许在整个链中进行有效的错误处理。

结论

总之,promise 是现代 javascript 的重要组成部分,使开发人员能够以更结构化和更高效的方式处理异步操作。通过使用 promise,您可以:

简化异步任务的管理,避免回调地狱。链接多个异步操作以保持清晰的执行流程。以统一的方式有效处理错误。

当您在自己的项目中实现 promise 时,您会发现它们不仅提高了代码的可读性,而且还通过保持应用程序的响应能力来增强整体用户体验。我希望这段 javascript 基本概念之旅能够为开发人员提供有价值的见解。快乐编码!

以上就是JavaScript Promise:您需要了解的基础知识的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1491968.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 14:25:33
下一篇 2025年12月19日 14:25:47

相关推荐

  • 探索 Neomjs:高性能 JavaScript 框架

    探索 Neo.mjs:现代 Web 应用程序的高性能 JavaScript 框架 在广阔的 Web 开发世界中,JavaScript 框架是构建动态和响应式应用程序的重要工具。虽然有许多流行的框架,如 React、Vue 和 Angular,但一个相对较新的竞争者正在掀起波澜:Neo.mjs。该框架…

    好文分享 2025年12月19日
    000
  • 探索 NFT 平台的发展和影响

    作为一名对区块链技术及其应用充满热情的开发人员,我最近在 NFT 领域开展了一个令人兴奋的项目。我的最新项目百慕大独角兽是一个综合性的 NFT 市场,旨在促进独特数字资产的创建、购买和销售。在这篇文章中,我想分享我的 NFT 网站的一个简短案例研究,以说明其开发过程及其对数字收藏品市场的影响。 案例…

    2025年12月19日
    000
  • (不可修改的引擎,React

    世界上有很多游戏引擎:Unreal Engine、Unity Engine、Godot Engine、Cry Engine等等。 这些游戏引擎有什么共同点?可定制性。不同的游戏有不同的要求,需要特定的功能来实现其目标。在单个程序中提供所有可能的功能是很困难的,这就是为什么许多引擎允许开发人员修改源代…

    2025年12月19日
    000
  • Nextjs 中间件简介:它如何工作并举例

    我们来谈谈nextjs中的路由。今天,我们来谈谈最强大的事物中间件之一。 nextjs 中的中间件提供了一种强大而灵活的方式来拦截来自服务器的请求并控制请求流(重定向、url 重写)并全局增强身份验证、标头、cookie 持久性等功能。 创建中间件 让我们创建 middleware next.js …

    2025年12月19日
    000
  • React 中的状态更新方法:性能

    在 react 中管理状态时,必须考虑两个关键点:性能和用户体验。 状态更新方法 更新状态时,可以使用以下方法: setcount(count + 1); 但是,虽然此方法可能看起来合适,但在异步更新期间访问先前的状态值时可能会导致问题。 2. 使用 prevstate 进行状态更新 如果新状态是根…

    2025年12月19日
    000
  • Analog 如何利用 Angular 彻底改变内容驱动网站

    多年来,许多开发人员在选择正确的框架来构建内容驱动的静态网站时都感到左右为难。虽然 Angular 因其强大的架构而一直受到青睐,但它缺乏有效创建此类网站的必要功能。 Analog 是一个改变了游戏规则的 Angular 元框架。本文将探讨 Analog 带来的好处,特别是对于那些希望创建内容驱动网…

    2025年12月19日
    000
  • 揭示算法和数据结构:高效编程的基础

    在这一系列文章中,我将分享我的学习历程,涉及在学术环境和大型科技公司中广泛讨论的两个主题:算法和数据结构。虽然这些主题乍一看似乎令人畏惧,特别是对于像我这样由于其他职业挑战而在整个职业生涯中没有机会深入研究这些主题的人,但我的目标是让它们变得容易理解。 我将从最基本的概念开始,然后转向更高级的主题,…

    2025年12月19日
    000
  • 你需要了解的 JavaScript 特性

    在本文中,我们将探讨如何在尝试访问可能未定义或 null 的数据时防止错误,并且我们将研究在必要时可用于有效管理数据的方法。 通过可选链接进行安全访问 在 javascript 中,当尝试访问嵌套对象中的值或函数时,如果结果为 undefined,您的代码可能会抛出错误。此错误可能会停止代码的执行。…

    2025年12月19日
    000
  • SQL 中的键 |主键 |外键|候选键|复合键|备用键|超级键|代理键|独特的钥匙

    在 SQL 中,键用于唯一标识表中的行、加强表之间的关系并维护数据完整性。钥匙有不同类型,每种都有特定的用途。以下是各种按键的详细说明和简单示例: 主键 主键唯一标识表中的每条记录。不能有NULL值,每个表只能有一个主键。 示例: 创建学生表( StudentID INT PRIMARY KEY, …

    2025年12月19日
    000
  • Vuejs 中计算属性的基础知识:组合 API

    计算属性 让我们考虑一个响应式对象: const author = reactive({ name: ‘john doe’, books: [ ‘vue 2 – advanced guide’, ‘vue 3 – basic guide’, ‘vue 4 – the mystery’ ]}) 在此对…

    2025年12月19日
    000
  • 关于 UUID 您需要了解的一切

    通用唯一标识符 (uuid) 是计算机系统中用于唯一标识信息的 128 位标签。 uuid 被设计为在空间和时间上都是唯一的,允许它们在没有中央权威的情况下独立生成,从而最大限度地减少重复的风险。 uuid 有多种用途,包括: 识别数据库中的记录。标记分布式系统中的对象。在唯一性至关重要的应用程序中…

    2025年12月19日
    000
  • 使用 Nodejs 构建实时仪表板

    介绍 在当今快节奏的商业世界中,组织访问实时数据以做出明智的决策至关重要。这就是使用 node.js 构建实时仪表板发挥作用的地方。 node.js 是一种流行的、轻量级的、高效的 javascript 运行时环境,近年来获得了极大的普及。在本文中,我们将讨论专门使用 node.js 构建实时仪表板…

    2025年12月19日
    000
  • 为什么每个网站都应该使用 HTTPS

    在当今的数字时代,在线安全对于任何网站都至关重要,无论是个人博客还是电子商务平台。保护站点安全的一个关键步骤是实施 HTTPS,这是 HTTP 的安全版本,它对浏览器和服务器之间交换的数据进行加密。 什么是 HTTPS? HTTPS(安全超文本传输​​协议)使用 SSL/TLS 加密数据,确保密码、…

    2025年12月19日
    000
  • 如何在Chrome中使用AI实验API

    要在 chrome 中使用实验性 ai api,请按照以下步骤操作: 硬件要求 4gb 内存gpu 可用至少 22gb 空间windows 10.11 或 macos ventura 或更新版本(无 linux 规范) 尚不支持: chrome操作系统chrome ioschrome 安卓 软件要求…

    2025年12月19日
    000
  • 在 Electron 中创建主进程和渲染进程之间的同步存储

    查看我们关于在 Electron 中的主进程和渲染器进程之间创建同步存储的最新博客。 使用 Electron 构建桌面应用程序时,一个常见的挑战是管理处理核心逻辑的主进程和负责 UI 的多个渲染器进程之间的共享状态。这些进程通常需要同步访问用户首选项或应用程序状态等数据。 由于 Electron 本…

    2025年12月19日
    000
  • Angular 和 15 的改进

    1) 在 angular 14 中注入服务,无需使用注入构造函数。以前,注入任何服务总是需要具有构造函数的类: class myclass { constructor(private myservice: myservice) {}} 现在,我们可以在函数和类中注入服务。我们只需要声明一个变量并将其…

    2025年12月19日
    000
  • 列表中与 map、forEach 和其他方法的交互

    当我们使用现代编程语言处理列表时,通常会找到几种方法来迭代其元素并对它们执行操作。最流行的结构包括 map、foreach、filter 和其他方法。这些方法对于任何想要编写更简洁、高效和可读的代码的人来说都是必不可少的。让我们来探讨一下这些方法、它们的区别、优点以及如何正确使用它们。 1.fore…

    2025年12月19日
    000
  • 每个开发人员都应该了解的核心 React 概念

    掌握 react:关键概念综合指南 react 彻底改变了我们构建用户界面的方式。本指南将引导您了解基本的 react 概念,帮助您了解如何创建动态、高效且可维护的应用程序。 jsx 和动​​态值react 的核心优势之一是 jsx,它允许您在标记中使用动态 javascript 值。您可以使用花括…

    2025年12月19日
    000
  • 解锁性能:了解总阻塞时间 (TBT)

    在 Web 开发领域,优化网站性能是提供无缝用户体验的关键因素。总阻塞时间 (TBT) 是一个重要的 Web 性能指标,用于量化页面加载过程中交互延迟的程度。在本文中,我们将深入探讨 TBT 的概念,探讨其在衡量用户体验方面的重要性,并讨论改进它的有效策略,从而打造更快、响应更快的网站。 了解总阻塞…

    2025年12月19日
    000
  • 理解 Reactmemo:优化功能组件

    react.memo 是 react 中使用的高阶组件,通过防止功能组件不必要的重新渲染来优化性能。它的工作原理是记住组件的结果,并且仅在其 props 发生变化时重新渲染它。这对于在给定相同 props 的情况下呈现相同输出的功能组件的性能优化非常有用。 用法示例: import react fr…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信