Promise异步编程

news2025/1/13 13:53:06

目录

一、Promise的含义

二、基本用法

三、reject的用法

四、执行顺序

五、  项目中使用promise获取后端数据

 六、catch的用法

七、finally的用法

八、Promise.all()

 九、Promise.all()有一个是失败

十、Promise.race()全部是成功

 十一、Promise.race()有一个是失败


一、Promise的含义

Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数——更合理和更强大。它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Promise对象。

所谓Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果。从语法上说,Promise 是一个对象,从它可以获取异步操作的消息。Promise 提供统一的 API,各种异步操作都可以用同样的方法进行处理。

promise翻译: 许诺;承诺;答应;保证;使很可能;预示

二、基本用法

ES6 规定,Promise对象是一个构造函数,用来生成Promise实例。

  const baseFun = () => {
    console.log(1)
    const promise = new Promise(function (resolve, reject) {
      setTimeout(() => {
        resolve({
          code: 200,
          data: {
            title: '通过resolve返回的数据',
          },
          msg: '成功',
        })
      }, 1000)
    })
    promise.then((res) => {
      if (res.code === 200) {
        setTitle(res.data.title)
      }
    })
  }

Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolvereject。它们是两个函数,由 JavaScript 引擎提供,不用自己部署。

resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;reject函数的作用是,将Promise对象的状态从“未完成”变为“失败”(即从 pending 变为 rejected),在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。

Promise实例生成以后,可以用then方法分别指定resolved状态和rejected状态的回调函数。

三、reject的用法

then方法可以接受两个回调函数作为参数。第一个回调函数是Promise对象的状态变为resolved时调用,第二个回调函数是Promise对象的状态变为rejected时调用。这两个函数都是可选的,不一定要提供。它们都接受Promise对象传出的值作为参数。

  //reject的用法
  const baseRejectFun = () => {
    const promise = new Promise(function (resolve, reject) {
      setTimeout(() => {
        reject({
          code: 400,
          data: {
            title: '通过reject返回的数据',
          },
          msg: '失败',
        })
      }, 1000)
    })
    promise.then(
      (res) => {
        if (res.code === 200) {
          setTitle(res.data.title)
        }
      },
      (res) => {
        if (res.code === 400) {
          setTitle(res.data.title)
        }
      }
    )
  }

四、执行顺序

Promise 新建后就会立即执行。

  //执行顺序
  const baseOrderFun = () => {
    const promise = new Promise(function (resolve, reject) {
      console.log('promise')
      resolve()
      console.log('promise2')

    })
    promise.then((res) => {
      console.log('resolved')
    })
    console.log('other')
  }

Promise 新建后立即执行,所以首先输出的是Promise。然后,then方法指定的回调函数,将在当前脚本所有同步任务执行完才会执行,所以resolved最后输出。

五、  项目中使用promise获取后端数据

  //项目中使用promise获取后端数据
  const baseApiFun = () => {
    Api.h5.userGetInfo({}).then((res) => {
      if (res.code === 200) {
        setTitle(res.data.nickname)
      }
  })

 六、catch的用法

Promise.prototype.catch()方法是.then(null, rejection).then(undefined, rejection)的别名,用于指定发生错误时的回调函数。

  //catch的用法
  const baseCatchFun = () => {
    const promise = new Promise(function (resolve, reject) {
      setTimeout(() => {
        reject({
          code: 400,
          data: {
            title: '通过reject返回的数据',
          },
          msg: '失败',
        })
      }, 1000)
    })
    promise
      .then((res) => {
        if (res.code === 200) {
          setTitle(res.data.title)
        }
      })
      .catch((res) => {
        if (res.code === 400) {
          setTitle(res.data.title)
        }
      })
  }

一般来说,不要在then()方法里面定义 Reject 状态的回调函数(即then的第二个参数),总是使用catch方法。

七、finally的用法

finally()方法用于指定不管 Promise 对象最后状态如何,都会执行的操作

  //finally的用法
  const baseFinallyFun = () => {
    const promise = new Promise(function (resolve, reject) {
      setTimeout(() => {
        reject({
          code: 400,
          data: {
            title: '通过reject返回的数据',
          },
          msg: '失败',
        })
      }, 1000)
    })
    promise
      .then((res) => {
        if (res.code === 200) {
          setTitle(res.data.title)
        }
      })
      .catch((res) => {
        if (res.code === 400) {
          setTitle(res.data.title)
        }
      }).finally(() => {
        console.log('finally')
      })
  }

八、Promise.all()

Promise.all()方法用于将多个 Promise 实例,包装成一个新的 Promise 实例。

const p = Promise.all([p1, p2, p3]);

上面代码中,Promise.all()方法接受一个数组作为参数,p1p2p3都是 Promise 实例,如果不是,就会先调用下面讲到的Promise.resolve方法,将参数转为 Promise 实例,再进一步处理。另外,Promise.all()方法的参数可以不是数组,但必须具有 Iterator 接口,且返回的每个成员都是 Promise 实例。

p的状态由p1p2p3决定,分成两种情况。

(1)只有p1p2p3的状态都变成fulfilledp的状态才会变成fulfilled,此时p1p2p3的返回值组成一个数组,传递给p的回调函数。

(2)只要p1p2p3之中有一个被rejectedp的状态就变成rejected,此时第一个被reject的实例的返回值,会传递给p的回调函数。

  //Promise.all()
  const baseAllFun = () => {
    const promise1 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        resolve({
          code: 200,
          data: {
            title: '通过resolve返回的数据',
          },
          msg: '成功',
        })
      }, 1000)
    })
    const promise2 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        resolve({
          code: 200,
          data: {
            title: '通过resolve返回的数据2',
          },
          msg: '成功2',
        })
      }, 1000)
    })
    const promiseAll = Promise.all([promise1, promise2])
    promiseAll
      .then((res) => {
        console.log(res)
      })
      .catch((res) => {
        if (res.code === 400) {
          setTitle(res.data.title)
        }
      })
  }

 九、Promise.all()有一个是失败

  //Promise.all()有一个是失败
  const baseAllWithRejectFun = () => {
    const promise1 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        reject({
          code: 400,
          data: {
            title: '通过reject返回的数据',
          },
          msg: '失败',
        })
      }, 1000)
    })
    const promise2 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        reject({
          code: 400,
          data: {
            title: '通过reject返回的数据2',
          },
          msg: '失败2',
        })
      }, 1000)
    })
    const promiseAll = Promise.all([promise1, promise2])
    promiseAll
      .then((res) => {
        console.log(res)
      })
      .catch((res) => {
        console.log('catch', res)
      })
  }

十、Promise.race()全部是成功

Promise.race()方法同样是将多个 Promise 实例,包装成一个新的 Promise 实例。

const p = Promise.race([p1, p2, p3]);

上面代码中,只要p1p2p3之中有一个实例率先改变状态,p的状态就跟着改变。那个率先改变的 Promise 实例的返回值,就传递给p的回调函数。

  const baseRaceFun = () => {
    const promise1 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        resolve({
          code: 200,
          data: {
            title: '通过resolve返回的数据',
          },
          msg: '成功',
        })
      }, 5000)
    })
    const promise2 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        resolve({
          code: 200,
          data: {
            title: '通过resolve返回的数据2',
          },
          msg: '成功2',
        })
      }, 1000)
    })
    const promiseRace = Promise.race([promise1, promise2])
    promiseRace
      .then((res) => {
        console.log(res)
      })
      .catch((res) => {
        console.log(res)
      })
  }

 十一、Promise.race()有一个是失败

  //Promise.race()有一个是失败
  const baseRaceWithRejectFun = () => {
    const promise1 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        resolve({
          code: 200,
          data: {
            title: '通过resolve返回的数据',
          },
          msg: '成功',
        })
      }, 5000)
    })
    const promise2 = new Promise(function (resolve, reject) {
      setTimeout(() => {
        reject({
          code: 400,
          data: {
            title: '通过reject返回的数据2',
          },
          msg: '失败2',
        })
      }, 1000)
    })
    const promiseRace = Promise.race([promise1, promise2])
    promiseRace
      .then((res) => {
        console.log(res)
      })
      .catch((res) => {
        console.log('catch', res)
      })
  }

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

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

相关文章

Java——二叉树中和为某一值的路径(二)

题目链接 牛客网在线oj题——二叉树中和为某一值的路径(二) 题目描述 输入一颗二叉树的根节点root和一个整数expectNumber,找出二叉树中结点值的和为expectNumber的所有路径。 1.该题路径定义为从树的根结点开始往下一直到叶子结点所经过…

图的相关知识总结

目录 图的概念图的存储结构邻接矩阵邻接表 图的遍历最小生成树Kruskal算法prim算法 最短路径问题单源最短路径--Dijkstra算法-单源最短路径--Bellman-Ford算法多源最短路径--Floyd-Warshall算法 图的概念 图是有顶点集合以及顶点间的关系组成的一种数据结构:G(V,E),其中顶点集…

JS-11A/224时间继电器 JOSEF约瑟 板前、板后接线

系列型号: JS-11A/11集成电路时间继电器;JS-11A/12集成电路时间继电器; JS-11A/13集成电路时间继电器;JS-11A/136集成电路时间继电器; JS-11A/137集成电路时间继电器;JS-11A/22集成电路时间继电器&#…

Java基础(十二)Java比较器

1 Java 比较器 我们知道基本数据类型的数据(除boolean类型外)需要比较大小的话,直接使用比较运算符即可,但是引用数据类型是不能直接使用比较运算符来比较大小的。那么,如何解决这个问题呢? 在Java中经常…

Jomalone(“独狼”)的Rootkit后门dll分析

从England.sys(md5为B5F7DE342B1D661E57BCD14615CADEFA)驱动文件中提取了4个dll文件,其中两个64位dll,两个32位dll,主要用于APC注入 样本的基本信息 文件名称: 0x3df60-0x15e00.dll 文件大小: 87.5 KB (89,600 字节) …

Kubeadm方式搭建K8s集群【1.23.0版本】

文章目录 一、初始化准备二、安装kubeadm三、初始化Master集群四、将新的Node节点加入集群五、部署CNI网络插件六、其他配置 Kubernetes1.24(包括1.24)之后不在兼容docker,如果有需要兼容docker的需求,则安装一个 cri-docker的插件,本文使用的是kuberne…

【SWAT水文模型】ArcSWAT输入准备

ArcSWAT输入准备 1 必需的ArcSWAT空间数据集1.1 数字高程模型(DEM)1.2 土地覆盖/土地利用类型1.3 土壤数据 2 可选的ArcSWAT空间数据集2.1 DEM Mask2.2 Streams2.3 User- Defined Watersheds 3 ArcSWAT表格和文本文件3.1 子流域出口位置表(dBase 表)3.2 …

【MCAL_Uart】-1.1-图文详解Uart串口协议

目录 1 什么是UART 2 UART的电平 3 UART的波特率 4 UART帧格式 4.1 start bit起始位 4.2 data bit数据位 4.3 parity bit奇偶校验位 4.4 stop bit停止位 5 什么是8-N-1 6 UART总线负载率计算 结尾 优质博文推荐阅读(单击下方链接,即可跳转&am…

shell脚本基础之详解脚本的控制

详解脚本的控制 信号的处理Linux信号生成信号中断进程暂停进程 捕获信号捕获脚本退出修改或移除捕获 以后台模式运行脚本后台运行脚本运行多个后台脚本 在非控制台下运行脚本作业控制 查看作业重启停止的作业调整谦让度nice命令renice命令 定时运行作业用 at 命令来定时执行作业…

2023移动云大会即将召开,划重点来了

今年由 ChatGPT 引起的AI浪潮下,人们热议其背后的算力问题,毋庸置疑,算力已成为和水电同样重要的资源。作为开发者,如何了解云计算领域有哪些最新发展趋势? 4月25-26日,以“云擎未来,智信天下”…

Scala之集合(3)

目录 WordCount案例: 需求分析与步骤: 拆分: 聚合: 格式转化: 方法1: 方法2: 排序: 方法1: 方法2: 取top3: 整体化简后的代码&#xf…

轻量级服务器nginx:配置虚拟主机的两种方式

虚拟主机是指,在一台服务器中,通过nginx的代理,我们可以访问多个网站。区分不同的网站,可以通过端口、域名两种方式 这里写目录标题 一 端口不同区分不同的虚拟主机二 通过域名区分不同的主机名1.配置域名映射2.显示登录效果 一 …

基于ATECLOUD电源模块及单板性能自动化测试方案

一、背景介绍 客户使用直流电源、交流电源、直流负载、示波器、数据记录仪、功率分析仪、CAN卡、工控机等仪器对电源模块及单板进行功能和性能方面的测试,目前想要能够通过硬件自动化测试分析系统搭配对应仪器实现自动化测试,提升测试效率。 二、用户痛…

Linux网络——NFS共享服务

Linux网络——NFS共享服务 一、NFS共享服务1.NFS网络文件系统2.NFS 架构3.NFS 工作原理4.NFS相关配置文件及其配置作用 二、搭建NFS服务1.服务器安装 nfs-utils、rpcbind 软件包2.服务器启动nfs-utils、rpcbind服务,并设置共享目录3.服务端更改NFS配置,对…

scrapy实践-02

双师demo ptpress.com.cn/shopping/index 解析每一首歌 <ul class"f-hide"><li><a href"/song?id2037945324">芯房</a></li><li><a href"/song?id2037926385">知足</a></li><li>…

QMS-云质说质量 - 3 来料检验的九大坑,你踩过几个?

大家好&#xff0c;今天我们来讲一讲来料检验。 先重点强调一下&#xff0c;我们讨论的范围是采购大量零部件的离散制造企业&#xff0c;而不是全部类型的企业。 负责来料检验的是IQC部门。相对于整个公司的组织架构来说&#xff0c;IQC是一个很小、很小的部门。负责的事情也很…

2023找工作,怎么样才能成功跳槽面试拿到高薪呢?

前言 无论是在校招还是社会企业招聘中&#xff0c;应聘者总是要经过层层的考核才能被聘用。然而&#xff0c;在招聘时&#xff0c;设置的编程以及非技术面试问题&#xff0c;真的有必要吗&#xff1f;如此就能考核出一位开发者的真实水平&#xff1f; 说到底就是考验你的技术以…

WSL2 对外暴露端口

参考文档 一口气搞定 WSL2 的网络问题从局域网 (LAN) 访问 WSL 2 发行版通过本地网络连接到 WSL2 服务器 按照下面的操作步骤进行操作。 1. powershell 支持 sudo https://github.com/gerardog/gsudo 可以直接下载msi安装&#xff1a;https://github.com/gerardog/gsudo/rel…

excel数据分析比赛

基础 sql:百度网盘 请输入提取码 excel函数 <

Git+SpringBoot详谈

&#x1f648;作者简介&#xff1a;练习时长两年半的Java up主 &#x1f649;个人主页&#xff1a;老茶icon &#x1f64a; ps:点赞&#x1f44d;是免费的&#xff0c;却可以让写博客的作者开兴好久好久&#x1f60e; &#x1f4da;系列专栏&#xff1a;Java全栈&#xff0c;计…