位置: IT常识 - 正文

ES6---promise详解及用法(es6 promise finally)

编辑:rootadmin
ES6---promise详解及用法 一、什么是Promise

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

文章相关热门搜索词:es6 详解,es6 详解,es6 from,es6 promise.all,es6 from,es6 promise finally,es6 promise finally,es6 promise finally,内容如对您有帮助,希望把文章链接给更多的朋友!

Promise是ES6异步编程的一种解决方案(目前最先进的解决方案是async和await的搭配(ES8),但是它们是基于promise的),从语法上讲,Promise是一个对象或者说是构造函数,用来封装异步操作并可以获取其成功或失败的结果。  

二、为什么要使用promise

最重要也是最主要的一个场景就是ajax和axios请求。通俗来说,由于网速的不同,可能你得到返回值的时间也是不同的,但是我们下一步要执行的代码依赖于上一次请求返回值,这个时候我们就需要等待,结果出来了之后才知道怎么样继续下去。 

三、promise的好处

1.可以避免多层异步调用嵌套问题(回调地狱) 2.Promise 对象提供了简洁的API,使得控制异步操作更加容易(js执行机制导致的异步问题)这两点在我ES6专栏的相关文章有很详细的介绍,这里就不展开了

 四、promise的三种状态

Promise对象有三种状态,他们分别是:

1.pending: 等待中,或者进行中,表示还没有得到结果 2.resolved(Fulfilled): 已经完成,表示得到了我们想要的结果,可以继续往下执行 3.rejected: 也表示得到结果,但是由于结果并非我们所愿,因此拒绝执行 

这三种状态不受外界影响,而且状态只能从pending改变为resolved或者rejected,并且不可逆

五、promise的用法 1.promise的实例方法

①then()得到异步任务的正确结果

②catch()获取异常信息

③finally()成功与否都会执行(尚且不是正式标准)  注意:then方法可以接受两个函数,第一个函数为promise状态为成功的回调函数,第二个函数为promise状态为失败的回调函数(可以不写,一般用catch方法捕获promise状态为失败的异常信息)

 2.promise的对象方法(p1,p2,p3为promise的实例对象)

①Promise.all()并发处理多个异步任务,所有任务都执行完成才能得到结果

Promise.all( [p1,p2,p3] ) .then ( (result) => {consoleog (result)})

②Promise.race()并发处理多个异步任务,只要有一个任务完成就能得到结果  

Promise.race ( [p1,p2,p3] ).then ( (result)=>{console. log (result)})六、promise的特点 1.在Promise对象的构造函数中,将一个函数作为第一个参数。2.而Promise对象的构造函数的第一个参数中的这个函数,就是用来处理Promise的状态变化,这个函数的第一个参数表示promise的状态为成功,第二个参数表示promise的状态为失败,这两个参数(名字可以自己命名)都为一个函数,他们的作用分别是将promise状态修改为resolved(成功)和rejected(失败)。 <script> function fn(flag) { //构造函数 return new Promise(function(resolve, reject) { if (flag === true) { resolve('promise状态为成功!') }; if (flag === false) { reject('promise状态失败!') }; }) } console.log(fn(true)); </script>

 控制台运行:

3. Promise对象中的then方法,可以接收构造函数中处理的状态变化,并分别对应执行。then方法有2个函数参数,第一个函数接收resolved(promise状态为成功)的执行,第二个函数接收reject(promise状态为失败)的执行。  <script> function fn(flag) { return new Promise(function(resolve, reject) { if (flag === true) { resolve('promise状态为成功!') }; if (flag === false) { reject('promise状态失败!') }; }).then(function(res) { console.log(res); }, function(err) { console.log(err); }) } fn(true) fn(false) </script>ES6---promise详解及用法(es6 promise finally)

控制台运行:

4.promise的状态只能从 未完成->完成, 未完成->失败 且状态不可逆转。promise的异步结果,只能在完成状态时才能返回,而且我们在开发中是根据结果来选择来选择状态的,然后根据状态来选择是否执行then()。实例化的Promise内部会立即执行,then方法中的异步回调函数会在脚本中所有同步任务完成时才会执行。因此,promise的异步回调结果最后输出。示例代码如下:  var promise = new Promise(function(resolve, reject) { console.log('Promise instance'); resolve();});promise.then(function() { console.log('resolved result');});for(var i=0;i<100;i++) {console.log(i);/*Promise instance123...99100resolved result*/ 5.Promise.then()方法

①then()函数返回的实际也是一个Promise对象(无论函数内部返回什么类型的数据,函数都会进行加工返回一个promise对象)

<script> function fn(flag) { return new Promise(function(resolve, reject) { if (flag === true) { resolve('promise状态为成功!') }; if (flag === false) { reject('promise状态失败!') }; }) } console.log(fn(true).then()); </script>

控制台运行:

 

 ②then()函数内部返回为普通值(非Promise类型的属性),返回的普通值会直接传递给下一个then,通过then参数中函数的参数接收该值。

这时then()函数返回的Promise对象状态为成功(resloved),then()函数的返回值为对象的成功值,如return 123,返回的Promise对象值为123,如果没有返回值,是undefined

<script> const p = new Promise((resolve, reject) => { setTimeout(() => { resolve('用户数据'); }) }); let result = p.then(value => { return 123; }, reason => { console.log(reason) }) console.log(result); result.then(function(res) { console.log(res); }) </script>

控制台运行:

  

③ 当then()函数内部返回的是Promise类型的对象时,then()函数的返回的Promise对象的状态值为这个Promise对象的状态值,成功值也是如此,返回的该promise对象会调用下一个then方法。

<script> const p = new Promise((resolve, reject) => { setTimeout(() => { resolve('用户数据'); }) }); let result = p.then(value => { return new Promise((resolve, reject) => { resolve('ok') }) }, reason => { console.log(reason) }) console.log(result); result.then(function(res) { console.log(res); }) </script>

控制台运行:

 

 ④当then()函数内部果抛出异常,则then()函数的返回值状态也是rejected

<script> const p = new Promise((resolve, reject) => { setTimeout(() => { resolve('用户数据'); }) }); let result = p.then(value => { throw 123 }, reason => { console.log(reason) }) console.log(result); </script>

控制台运行:

 

6.Promise.catch()方法

①catch()函数只有一个回调函数,意味着如果Promise对象状态为失败就会调用catch()方法并且调用回调

//catch()函数只有一个回调函数,意味着如果Promise对象状态为失败就会调用catch()方法并且调用回调函数<script>const p = new Promise((resolve, reject) => {setTimeout(()=>{reject('出错啦')},1000)})p.catch(reason => {console.log(reason)})</script>

控制台运行:   

七、总结1.promise其实就是一个对象或者说是构造函数2.promise的出现(es6) 就是解决异步编程和回调地狱等问题,async和await的出现(ES8)就是基于promise的一种解决异步编程的终极解决方案(简化代码等等) 3.在前端中,ajax和axios都会用到异步编程,axios更是基于promise的,所以一定要掌握promise以及用async和await搭配promise的使用
本文链接地址:https://www.jiuchutong.com/zhishi/300674.html 转载请保留说明!

上一篇:3分钟让你学会axios在vue项目中的基本用法(建议收藏)(怎么才能学a1)

下一篇:【区块链实战】什么是 P2P 网络,区块链和 P2P 网络有什么关系(区块链教程大全)

  • mate40pro超级夜景怎么开(mate40pro+夜景)

    mate40pro超级夜景怎么开(mate40pro+夜景)

  • 硬盘是什么的一种(硬盘是什么以及作用是什么)

    硬盘是什么的一种(硬盘是什么以及作用是什么)

  • 公众号为什么取消留言(公众号为什么取消留言功能)

    公众号为什么取消留言(公众号为什么取消留言功能)

  • 10750h相当于桌面级什么cpu(10750h相当于桌面端什么cpu 贴吧)

    10750h相当于桌面级什么cpu(10750h相当于桌面端什么cpu 贴吧)

  • 华为手机密码最多输错几次(华为手机密码最多可以试多少次)

    华为手机密码最多输错几次(华为手机密码最多可以试多少次)

  • 芒果tv怎么看不到弹幕了(芒果tv怎么看不见了)

    芒果tv怎么看不到弹幕了(芒果tv怎么看不见了)

  • 苹果8怎么装两个卡(苹果8怎么装两个手机卡)

    苹果8怎么装两个卡(苹果8怎么装两个手机卡)

  • 能不能异地帮别人叫顺风车(能不能异地帮别人买医保)

    能不能异地帮别人叫顺风车(能不能异地帮别人买医保)

  • 拼多多隐形降权恢复期(拼多多隐形降权一般屏蔽多久)

    拼多多隐形降权恢复期(拼多多隐形降权一般屏蔽多久)

  • 100m光纤用几类网线(100兆光纤用几类网线)

    100m光纤用几类网线(100兆光纤用几类网线)

  • 机器语言程序在机器内是以什么形式表示(ai编程语言)

    机器语言程序在机器内是以什么形式表示(ai编程语言)

  • 手机屏幕边缘一道发黄(手机屏幕边缘一圈淡绿色)

    手机屏幕边缘一道发黄(手机屏幕边缘一圈淡绿色)

  • ps标尺怎么用(ps的标尺怎么使用)

    ps标尺怎么用(ps的标尺怎么使用)

  • 淘宝红包怎么领取(明星淘宝红包怎么领)

    淘宝红包怎么领取(明星淘宝红包怎么领)

  • 苹果11充电头多少w(苹果11充电头多少瓦)

    苹果11充电头多少w(苹果11充电头多少瓦)

  • 爱剪辑怎么两个视频同框(爱剪辑怎么两个画面同步)

    爱剪辑怎么两个视频同框(爱剪辑怎么两个画面同步)

  • 抖音怎么导入自己的音乐(抖音怎么导入自己的录音带字幕)

    抖音怎么导入自己的音乐(抖音怎么导入自己的录音带字幕)

  • 怎么才能恢复微信上的聊天记录(怎么才能恢复微信删除的好友)

    怎么才能恢复微信上的聊天记录(怎么才能恢复微信删除的好友)

  • 小米摄像头总是等待连接(小米摄像头总是链接失败)

    小米摄像头总是等待连接(小米摄像头总是链接失败)

  • 苹果xr怎么设置自拍不反(苹果xr怎么设置陌生号码电话拦截)

    苹果xr怎么设置自拍不反(苹果xr怎么设置陌生号码电话拦截)

  • 苹果id验证码在哪里输入(苹果id验证码在哪收)

    苹果id验证码在哪里输入(苹果id验证码在哪收)

  • 怎么开启支付宝刷脸支付(怎么开启支付宝余额支付功能)

    怎么开启支付宝刷脸支付(怎么开启支付宝余额支付功能)

  • 微信金山文档怎么在电脑上打开(微信金山文档怎么保存到电脑桌面上)

    微信金山文档怎么在电脑上打开(微信金山文档怎么保存到电脑桌面上)

  • qq诞生于哪一年哪一月(qq起始于哪一年)

    qq诞生于哪一年哪一月(qq起始于哪一年)

  • 三代税款手续费退费申请
  • 股东继续投资
  • 生产工人工资和福利费是产品成本项目对吗
  • 其他业务利润包括哪些科目
  • 小企业销售费用多少算高
  • 长期股权投资的4个明细科目
  • 企业资产业务收购税务处理怎么做?
  • 老板找人替我工作说明了什么
  • 研发部门属于哪个会计科目
  • 预收账款缴纳企税怎么算
  • 有限合伙企业无限合伙企业
  • 申报增值税附表二代不出数据
  • 普通发票税率为1%吗
  • 万元的票可以开到多大金额
  • 出租车库收入是否需要计算缴纳土地增值税
  • 可以背书转让的公司
  • 溢价转让股权的会计处理
  • 公司的固定资产如何转变为股东资产
  • 购物预付卡怎么用
  • 进口技术服务需要向海关备案吗
  • 购物卡发票能否抵扣
  • 合作社人工工资账务处理
  • 小规模纳税人增值税免税政策
  • 往来账乱如何处理
  • 长期待摊费用转入成本分录
  • 苹果手机密码忘记了怎么重置密码
  • linux format命令
  • intel me有什么用
  • 金融资产包括哪三大类及会计科目
  • 工程决算审计费收费标准
  • 查看chrome浏览器内核版本
  • 肚子胀气怎么办 4个方法快速排气很轻松
  • 预提收入需不需要计提增值税
  • phpmvc框架工作原理
  • react组件库有哪些
  • 深入理解ts
  • css字体设置渐变色
  • 增值税申报表中销售额
  • 固定资产停止使用还要折旧吗
  • phpcms v9用户手册
  • 如何检查文件是否有毒
  • 子公司减资是利好还是利空
  • 海关进口增值税专用缴款书稽核比对可能出现哪些结果
  • 毛利率在餐饮中的应用
  • sql无法运行
  • 个税手续费返还比例
  • 衍生工具属于什么科目
  • 未认证发票进项怎么处理
  • 0税率出口退税
  • 个人向公司借款流程
  • 收到其他应付款会计分录
  • 企业工资薪金支出怎么确认
  • 挂靠收入如何做账处理?
  • 农业生态有限公司成立条件
  • 企业所得税税负率多少合适
  • 固定资产加速折旧纳税调整
  • Windows Server 2008提升AD管理效率
  • torch.cuda.set_device
  • win8怎样关闭系统更新
  • ubuntu kylin 14.04下载 ubuntu优麒麟14.04 lts下载地址
  • centos7怎么看cpu和内存
  • win7无法更改设置
  • linux添加启动
  • win7 来宾账户
  • win7系统步骤
  • perl如何使用
  • [置顶]游戏名:chivalry2
  • Zxing在CameraManager.get().closeDriver()报错
  • unity3d音效
  • 用python抓取网页数据的代码
  • JavaScipt中Function()函数的使用教程
  • wpf窗口嵌套
  • NGUI学习:(1)spine导入后图层顺序的问题
  • android基于
  • 财税专家刘杨简历图片介绍
  • 重庆电子税务局网页版登录
  • 姓名验证不正确
  • 本期预缴税额怎么填
  • 转让专利权取得的所得属于财产转让所得吗
  • 报税日期2023年
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设