javascript中promise是什么_如何使用它

Promise 是 ES6 引入的内置对象,用于规范异步操作,具有 pending/fulfilled/rejected 三种不可逆状态;通过 new Promise() 创建,支持链式调用、值穿透及 Promise.all/race/resolve/reject 等静态方法。

javascript中promise是什么_如何使用它

Promise 是 JavaScript 中处理异步操作的一种标准方式,它代表一个尚未完成、但未来会完成(或失败)的操作的结果。 它不是语法糖,也不是新语言特性,而是 ES6 正式引入的内置对象,用来更清晰、可靠地管理回调函数嵌套(即“回调地狱”)的问题。

Promise 的三种状态

每个 Promise 实例始终处于以下三种状态之一:

pending(待定):初始状态,既没成功也没失败 fulfilled(已成功):操作成功完成,可调用 .then() 获取结果 rejected(已失败):操作出错,可调用 .catch() 捕获错误

状态一旦改变(pending → fulfilled 或 pending → rejected),就不可逆,也不会再变。

如何创建和使用 Promise

new Promise() 构造函数创建,它接收一个执行器函数(executor),该函数立即执行,并传入两个参数:resolvereject —— 它们是预定义的函数,分别用来把 Promise 变成成功或失败状态。

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

例如,模拟一个 1 秒后返回用户数据的异步请求:

const fetchUser = new Promise((resolve, reject) => {  setTimeout(() => {    const success = Math.random() > 0.2; // 80% 概率成功    if (success) {      resolve({ id: 123, name: "张三" });    } else {      reject(new Error("网络请求失败"));    }  }, 1000);});fetchUser  .then(user => console.log("获取成功:", user))  .catch(err => console.error("出错了:", err.message));

链式调用与值穿透

Promise 的最大优势之一是支持链式调用。每个 .then().catch() 都会返回一个新的 Promise,所以可以连续写多个 .then(),前一个的返回值会自动传给下一个。

如果 .then() 回调返回一个普通值(如字符串、数字),下一个 .then() 会接收到它 如果返回的是另一个 Promise,下一个 .then() 会等待它完成后再执行 .catch() 能捕获前面所有环节抛出的错误(包括 throw 和 Promise rejection)

比如:先获取用户,再根据 ID 请求订单,最后打印总数:

fetchUser  .then(user => fetch(`/api/orders?userId=${user.id}`))  .then(res => res.json())  .then(orders => console.log("订单数:", orders.length))  .catch(err => console.error("任一环节失败:", err));

常用静态方法:Promise.all、Promise.race、Promise.resolve/reject

除了实例方法,Promise 还提供几个实用的静态方法:

Promise.all([p1, p2, p3]):全部成功才成功,任意一个失败就立刻 reject(适合并行请求且都必须成功) Promise.race([p1, p2, p3]):哪个先完成(无论成功/失败),就以它的结果为准(可用于超时控制) Promise.resolve(value):快速创建一个立即成功的 Promise(等价于 new Promise(r => r(value))Promise.reject(error):快速创建一个立即失败的 Promise

例如用 Promise.race 实现超时:

const timeout = ms => new Promise((_, reject) =>   setTimeout(() => reject(new Error("请求超时")), ms));Promise.race([  fetch('/api/data'),  timeout(3000)]).then(res => res.json()).catch(err => console.error(err));

基本上就这些。Promise 不复杂但容易忽略细节,关键是理解“状态不可逆”和“链式返回新 Promise”这两个核心机制。现代开发中,它常和 async/await 一起用,后者只是 Promise 的语法糖,底层完全一致。

以上就是javascript中promise是什么_如何使用它的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何用javascript实现响应式设计_如何监听窗口大小?
上一篇 2025年12月21日 15:48:27
javascript中的单页应用如何架构_路由状态怎样管理
下一篇 2025年12月21日 15:48:37

相关推荐

  • JavaScript与CSS动画:实现平滑顺序淡入淡出效果并解决显示冲突

    本文深入探讨了如何利用css动画和javascript实现元素的顺序淡出淡入效果,并着重解决了因`display: none`立即应用而导致的淡出动画不播放问题。文章提供了基于`settimeout`和更健壮的`animationend`事件的解决方案,并进一步建议使用css `transition…

    2026年5月10日
    000
  • 深入理解Flex布局:flex: 1与内容宽度不均的挑战

    当Flex容器中的子元素都设置flex: 1时,它们可能不会呈现等宽,这通常是由于内容自身的最小宽度(min-content)限制所致。本文将深入探讨flex: 1的工作原理,解释内容如何影响Flex子元素宽度,并提供通过优化内容结构、调整flex属性值或采用CSS Grid布局来解决宽度不均问题的…

    2026年5月10日
    000
  • 忽略 Google App Engine Datastore 查询中的错误

    本文介绍如何在 Google App Engine (GAE) 的 Go 环境中使用 Datastore 查询时,优雅地处理 ErrFieldMismatch 错误。由于 Datastore 的灵活性,允许不同结构的实体以相同的名称存储,但在检索时可能因类型不匹配或缺少值而导致错误。本文将指导你如何…

    2026年5月10日
    000
  • php调用国际化的实现_php调用gettext实现多语言

    答案:PHP中常用gettext扩展实现国际化,通过启用扩展、创建.po/.mo文件、设置locale环境并调用_()函数实现多语言输出,支持动态切换与高效管理。 PHP 中实现国际化(i18n)最常用的方式之一是使用 gettext 扩展。它能高效支持多语言切换,适合中大型项目对语言包的管理需求。…

    2026年5月10日
    000
  • PHP Regex:在指定父级中精准匹配嵌套配置段落

    本文深入探讨了如何利用php正则表达式在复杂配置文件中,根据指定的父级容器精确匹配并提取嵌套的配置段落。通过引入`k`操作符,我们能够巧妙地丢弃匹配的父级上下文,从而只返回目标嵌套内容,有效解决了传统正则匹配中多余匹配的问题,显著提升了匹配的精确性和效率。 在处理复杂的配置文件或代码结构时,我们经常…

    2026年5月10日
    100
  • C++ multiset容器 允许重复元素集合

    C++ multiset与set的核心区别在于multiset允许重复元素而set不允许,multiset适用于需自动排序且容纳重复值的场景,如统计频次或维护有序序列。 C++ std::multiset 容器是一个有序集合,它允许你存储重复的元素。它本质上是一个关联容器,所有元素都会根据其值自动排…

    2026年5月10日
    000
  • html5使用drag和drop制作文件上传区 html5使用可视化上传的界面设计

    利用HTML5拖拽API实现文件上传,通过DataTransfer获取文件,FileReader读取预览,结合美化样式和交互反馈,提升用户体验。 用 HTML5 的 Drag 和 Drop 实现文件上传区,结合可视化界面设计,可以提升用户体验。核心是利用 DataTransfer 接口获取拖拽的文件…

    2026年5月10日
    000
  • Go语言实现程序暂停功能:两种方法详解

    本文详细介绍了在go语言中实现程序暂停功能的两种主要方法。首先,通过读取标准输入流等待用户按下回车键,这是一种简单易行的实现方式。其次,为了实现“按任意键继续”的效果,文章深入探讨了如何利用`golang.org/x/term`库将终端设置为“原始模式”(raw mode)来捕获单个字符输入。同时,…

    2026年5月10日
    000
  • 即将上线的Gata(GATA币)是什么?怎么样?GATA币技术路径和代币经济学概述

    目录 什么是 Gata:定位和产品边界应用程序/入口点和“可验证数据表面”架构:执行网络 × 数据与数据挖掘 × 应用协同工作应用层数据和存储层执行和 DA 层代币经济学:供应、分配和效用代币效用生态系统伙伴关系和外部信号近期进展和路线图常问问题关键要点 gata 同时构建了“应用程序可用性”和“去…

    2026年5月10日
    100
  • Go 语言中的匿名函数(Lambda 表达式)应用指南

    Go语言支持匿名函数,这与许多其他语言中的Lambda表达式概念相似。本文将深入探讨Go语言中匿名函数的定义、使用场景及其作为一等公民的特性,并通过代码示例展示如何在Go中实现类似Lambda的功能,帮助开发者理解并有效利用这一强大特性。 Go 语言中的匿名函数概述 在go语言中,匿名函数(anon…

    2026年5月10日
    000
  • JavaScript代码覆盖率与测试质量评估

    代码覆盖率不等于测试质量,需结合断言、边界测试和副作用验证;合理利用覆盖率工具如Istanbul和Jest,关注未覆盖分支,避免无断言调用;综合评估可维护性、稳定性及业务对齐,突变测试可进一步提升可靠性。 代码覆盖率和测试质量是衡量前端项目健壮性的重要指标。很多人误以为高覆盖率就等于高质量测试,但实…

    2026年5月10日
    000
  • 掌握CSS按钮悬停动画:使用Transition属性实现流畅交互

    本教程将详细介绍如何利用css的`transition`属性为html按钮实现平滑的悬停动画,无需复杂的javascript。文章将涵盖`transition`的基本用法、`:hover`伪类的应用,并通过代码示例演示如何改变背景、颜色和缩放效果,以提升用户界面的交互体验。 提升按钮交互体验:理解C…

    2026年5月10日
    000
  • Vue子组件向父组件传递数组报错:如何正确处理axios异步请求数据?

    vue子组件向父组件传递数组的异步处理方案 在Vue子组件中,使用axios进行异步请求后,向父组件传递数组数据时,可能会遇到传递失败或数据不完整的问题。这是因为axios请求是异步操作,在this.$emit()执行时,请求可能尚未完成,导致传递的数据为空或不正确。 为了解决这个问题,需要确保在a…

    2026年5月10日
    000
  • Golang 如何实现批量任务并发执行_Golang WaitGroup 与 Channel 应用实例

    使用WaitGroup和Channel可实现Go中安全的并发任务控制。1. WaitGroup通过Add、Done、Wait方法确保所有goroutine完成;2. Channel用于协程间通信,传递结果或错误;3. 主协程启动任务前调用Add,每个任务完成后调用Done并发送结果到channel;…

    2026年5月10日
    000
  • Electron嵌入远程网页:Iframe、WebView还是WebContents最佳?

    Electron最佳远程网页嵌入方案:WebContents 在Electron应用中集成并与远程网页交互,需要谨慎选择合适的API。本文将比较Iframe、WebView(已弃用,建议使用WebContents)和WebContents三种方案,并推荐最佳实践。 目标:在Electron应用中嵌入…

    2026年5月10日
    000
  • Go语言运行时自省:获取调用者包名与函数信息

    本文深入探讨了Go语言中通过runtime.Caller和runtime.FuncForPC进行运行时自省,以程序化方式获取调用者包名、文件路径、行号及函数名称的方法。文章提供了详细的代码示例,并分析了不同调用场景下的输出结果。同时,着重阐述了这些API在实际使用中可能遇到的局限性,如编译器内联的影…

    2026年5月10日
    000
  • HTML滑块(Slider)无法正常工作问题排查与解决方案

    本文旨在帮助开发者排查和解决HTML滑块()无法正常工作的问题。通过分析常见原因,例如JavaScript代码错误、CSS样式冲突以及HTML结构问题,提供详细的排查步骤和解决方案,并附带示例代码,帮助读者快速定位并修复问题,确保滑块功能正常运行。 HTML滑块()是一个常用的交互式元素,允许用户通…

    2026年5月10日
    000
  • Express.js 应用中跨模块共享与修改全局数组的教程

    在Express.js应用中,当需要在主应用文件与独立的路由模块之间共享并修改一个全局数组时,`app.locals`提供了一种简洁有效的解决方案。本文将详细介绍如何利用`app.locals`在`index.js`中定义一个数组,并在路由处理函数(如`module.js`)中安全地访问和更新该数组…

    2026年5月10日
    100
  • Golang Composite组合模式树形结构实现实践

    组合模式通过统一接口实现树形结构管理,适用于文件系统等场景。Go中用接口定义组件,结构体实现叶节点与复合节点,支持透明、递归操作,如目录与文件的统一处理。 在Go语言中,组合模式(Composite Pattern)是一种结构型设计模式,适用于构建树形结构的场景,比如文件系统、组织架构、菜单系统等。…

    2026年5月10日
    000
  • Golang值类型传递与指针传递比较

    Go语言中函数参数传递分为值传递和指针传递。值传递复制变量副本,函数内修改不影响原值,适用于小型数据类型如int、string等;示例中modifyValue函数对参数x的修改未影响外部变量a。指针传递通过传递地址实现共享内存,可修改原始数据,适合大型结构体或需变更原值场景;示例中modifyPoi…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信