位置: IT常识 - 正文

promise和async用法及区别(详解)(promise async区别)

编辑:rootadmin
promise和async用法及区别(详解) 一、promisepromise的概念

推荐整理分享promise和async用法及区别(详解)(promise async区别),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:async和promise区别,promise和async的用法,promise与async的区别,async和promise执行顺序,promise 和async,promise 和async,promise和async的用法,promise、async有什么区别,内容如对您有帮助,希望把文章链接给更多的朋友!

Promise 是异步编程的一种解决方案,是一个构造函数,自身有all、reject、resolve方法,原型上有then、catch等方法。

特点:

对象的状态不受外界影响。Promise对象代表一个异步操作,有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)

一旦状态改变,就不会再变,任何时候都可以得到这个结果。Promise对象的状态改变,只有两种可能:从pending变为fulfilled和从pending变为rejected。

一句话总结:就是用来解决地域回调问题(地域回调--回调函数里面嵌套回调函数)promise使用方法

用法一:Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve和reject。它们是两个函数,由JavaScript引擎提供。

resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从Pending变为Resolved),在异步操作成功时调用,并将异步操作的结果作为参数传递出去。

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

用法二:Promise.resolve() 和 Promise.reject() 可以直接被调用。有时候,当判断出 promise 并不需要真正执行时,我们并不需要 使用 new 创建 Promise 对象,而是可以直接调用 Promise.resolve() 和 Promise.reject()。

地狱回调的例子

回调地狱是为了让我们代码执行顺序的一种操作(解决异步),但是它会使我们的可读性非常差。

//地狱回调setTimeout(function () { //第一层console.log('小锁'); //等3秒打印张三在执行下一个回调函数setTimeout(function () { //第二层console.log('李四'); //等2秒打印李四在执行下一个回调函数setTimeout(function () { //第三层console.log('王五'); //等一秒打印王五}, 1000)}, 2000)}, 3000)promise解决地域回调function resolveCallback(name, flag = true) {return new Promise((resolve, reject) => {// 处理异步任务setTimeout(() => {if (flag) {resolve(name)} else {reject('失败')}}, 1000)}, )}resolveCallback('张三').then(res => {console.log(res)return resolveCallback('李四')}).then(res => {console.log(res)return resolveCallback('王五')}).then(res => {console.log(res)}).catch(res => { //捕捉失败的回调结果console.log(res)})Promise.all()方法

Promise.all([ .. ]) 接受一个或多个值的数组(比如,立即值、promise、thenable)。它返回一个promise。

如果所有的值都完成,这个promise 的结果是完成;

promise和async用法及区别(详解)(promise async区别)

一旦它们中的某一个被拒绝,那么这个promise 就立即被拒绝。

let p1 = resolveCallback('张三')let p2 = resolveCallback('李四')let p3 = resolveCallback('王五')let p = Promise.all([p1,p2,p3]).then(res=>{console.log(res)}).catch(res=>{console.log('失败')})Promise.race 方法

Promise.race() 函数返回一个 Promise,它将与第一个传递的 promise 相同的完成方式被完成。它可以是完成( resolves),也可以是失败(rejects),这要取决于第一个完成的方式是两个中的哪个。

let p1 = resolveCallback('张三', 2)let p2 = resolveCallback('李四', 3)let p3 = resolveCallback('王五', 1)let p = Promise.race([p1, p2, p3]).then(res => {console.log(res)}).catch(res => {console.log('失败')})二、asyncasync的概念

Async/Await 代码看起来简洁一些,使得异步代码看起来像同步代码

async函数一定会返回一个promise对象。如果一个async函数的返回值看起来不是promise,那么它将会被隐式地包装在一个promise中。

sync await是基于Promise实现的,可以说是改良版的Promise,它不能用于普通的回调函数。

async 函数中 return 值如何接收?

方式一:通过 promise.then形参获取

方式二:接受函数返回值的方式是 await

await的作用

await关键字的作用 就是获取 Promise中返回的内容, 获取的是Promise函数中resolve或者reject的值(await 作用是获取promise.[[promiseValue]]的值)

关于await的注意点

(1)await 必须写在 async 中

(2)await 后是一个promise实例对象

三、为什么async/await更好?

使用async函数可以让代码简洁很多

不需要像Promise一样需要then

不需要写匿名函数处理Promise的resolve的值

也不需要定义多余的data变量,还避免了嵌套代码

本文链接地址:https://www.jiuchutong.com/zhishi/294563.html 转载请保留说明!

上一篇:创建vue2项目(vue创建项目后开始写的步骤)

下一篇:Vue中二级菜单的实现(vue二级菜单的隐藏与显示)

  • 无法收回的应收账款可以税前扣除吗
  • 期初未缴税额是什么意思
  • 生产税净额计算实例
  • 保单的增值税发票
  • 金融工具减值的简化处理
  • 社保公积金计提是本月计提下月
  • 企业间的合作
  • 经营租赁的资产应计入哪里
  • 资本公积科目余额能出现小数吗
  • 以前年度损益是所有者权益吗
  • 筹建期的行政罚款的账务处理怎么做?
  • 营改增后取得土地转让
  • 已经缴纳税款怎么作废申报
  • 关于增值税专用发票
  • 其他业务收入是什么意思
  • 航空公司按照一次性收费
  • 如何确认是否要割包皮
  • 预缴企业所得税分录
  • 没有发生关联交易需要关联申报吗?
  • 工资年终奖金扣多少税
  • 地方教育附加什么时候交
  • 付出去的款项退回怎么做账
  • 连续亏损的公司还要去吗
  • 电脑重装系统启动
  • 在win7系统中将打开窗口拖到屏幕顶端
  • Win11怎么打开网络适配器
  • win10提示病毒
  • .ctc文件
  • 工程竣工决算会计账务处理
  • 建筑企业预缴企业所得税怎么计算
  • 建筑行业有哪些岗位,从事的要求有哪些
  • yarn的配置
  • 新会计准则2020变化
  • vue3+ts+vite
  • thinkphp验证码刷新
  • 专家评审费可以由中标人支付吗
  • 提存计划怎么算
  • 框架如何使用
  • php dao
  • springmvc执行流程简单
  • php json_encode与json_decode详解及实例
  • 一阶段目标检测算法
  • 政府奖励怎么做会计分录
  • 公司购买空调计入什么费用
  • 刷pos机的如何记会计分录
  • 看望员工现金属于什么费用
  • 冲销上个月成本的会计分录
  • 在建工程如何转固
  • 确认收入的时点包括
  • 开发成本的会计科目编码
  • 购进溢余分录
  • 项目独立性
  • 借款收据怎样才有法律效力
  • 研发支出是科目吗
  • 计提资产减值是好事还是坏事
  • mysql where clause
  • 未知文件怎么删除
  • debian和ubuntu命令一样吗
  • unix系统采用什么结构
  • linux做代理服务器的方法
  • qtaet2s.exe - qtaet2s是什么进程 有什么用
  • win7如何查询电脑使用记录
  • 系统自动保存文件在哪里
  • ExtJS下 Ext.Direct加载和提交过程排错小结
  • Unity3D游戏开发pdf
  • nodejs开发博客
  • 从零开始学什么
  • android颜色值
  • android DefaultHttpClient设置setCookieStore
  • python系统框架
  • js能写贪吃蛇游戏是什么水平
  • 工会经费申报表在哪里查询
  • 如何税务监管更精准
  • 中欧班列补贴政策
  • 股权收购的好处
  • 满五唯一是指省内还是本市
  • 河北省云办税厅
  • 2020江苏省禁钓规定
  • 税务窗口岗位职责
  • 辽宁省医保明细查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设