专业游戏门户,分享手游网游单机游戏百科知识攻略!

嗨游网
嗨游网

promise的用法是什么

来源:小嗨整编  作者:小嗨  发布时间:2023-03-02 12:03
摘要:promise的用法是什么?同步编程通常来说易于调试和维护,然而,异步编程通常能获得更好的性能和更大的灵活性。异步的最大特点是无需等待。Promises渐渐成为JavaScript里最重要的一部分,大量的新API都开始promise原...

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

promise的用法是什么

  promise的用法是什么?同步编程通常来说易于调试和维护,然而,异步编程通常能获得更好的性能和更大的灵活性。异步的最大特点是无需等待。Promises渐渐成为JavaScript里最重要的一部分,大量的新API都开始promise原理实现。下面让我们看一下什么是promise以及javascript promise的用法。

Promises现状

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Tahoma; color: #333333; -webkit-text-stroke: #333333}span.s1 {font-kerning: none}

XMLHttpRequest API是异步的,但它没有使用promise API。但有很多原生的 javascript API 使用了promise:

  *Battery API

  *fetch API (XHR的替代品)

  *ServiceWorker API

  Promises将来只会变得越来越流行、普遍,非常重要,所有的前端开发人员都将用到它。另一个值得注意的是,Node.js是基于Promises的平台(很显然,Promise是它的一个核心特征)。

  Promise的用法比你想象的要简单——如果你以前喜欢使用setTimeout来控制异步任务的话!

Promise基本用法

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  new Promise()构造器可以用在传统的异步任务中,就像以前 setTimeout 和 XMLHttpRequest 的用法一样。一个新的 Promise 使用 new 关键字生成,同时,这个 Promises 提供了 resolve 和 reject 函数让我们执行回调操作:

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

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

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  因为 promise 肯定会返回,所以,我们可以使用 then 和 catch 方法处理返回值!

then 方法

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; color: #800000; -webkit-text-stroke: #000000}p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  所有的 promise 对象实例里都有一个 then 方法,它是用来跟这个 promise 进行交互的。首先,then 方法会缺省调用 resolve() 函数:

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  then 回调动作的触发时机是 promise 被执行完。我们还可以串联 then 方法执行回调操作:

  你会发现,每次 then 调用都会以之前的 then 调用的返回值为参数。

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  如果一个 promise 已经执行完成,单 then 被再次调用时,回调动作将会被再次执行。而如果这个 promise 里执行的是reject 回调函数,这是再调用 then 方法,回调函数将不会被执行。

catch 方法

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  catch 当一个 promise 被拒绝(reject)时,catch 方法会被执行:

  通常我们在 reject 方法里处理执行失败的结果,而在catch 里执行异常结果:reject(Error('Data could not be found'));

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}span.s1 {font-kerning: none}

  至此,关于promise的用法就简单的介绍到这里了。Promises在过去几年是一个非常火爆的话题,它甚至从JavaScript里抽离出来变成了一个语言架构。相信很快我们将见到有愈来愈多的JavaScript API将使用以promise为基础的模式,学会promise的用法能简化你在JavaScript中的操作。

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Tahoma; color: #333333; -webkit-text-stroke: #333333}p.p3 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px 'PingFang SC'; -webkit-text-stroke: #000000; background-color: #ffffff}p.p4 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px 'PingFang SC'; -webkit-text-stroke: #000000; background-color: #ffffff; min-height: 20.0px}p.p5 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; color: #800000; -webkit-text-stroke: #000000}p.p6 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Tahoma; color: #3366ff; -webkit-text-stroke: #3366ff}span.s1 {font-kerning: none}p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Tahoma; -webkit-text-stroke: #000000}p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Tahoma; color: #3366ff; -webkit-text-stroke: #3366ff}span.s1 {font-kerning: none}

本文地址:IT知识频道 https://www.eeeoo.cn/itzhishi/906928.html,嗨游网一个专业手游免费下载攻略知识分享平台,本站部分内容来自网络分享,不对内容负责,如有涉及到您的权益,请联系我们删除,谢谢!


IT知识
小编:小嗨整编
相关文章相关阅读
  • beta版是什么意思(iOS 15首个beta版本)

    beta版是什么意思(iOS 15首个beta版本)

    beta是什么意思(iOS15之一个测试版)苹果在WWDC21全球开发者大会上公布了所有平台的最新操作系统。显然,兼容性是果粉非常关心的问题。iOS15适合哪些机型?根据之前的推测,苹果的最新系统最多可以支持五年前的机型。去年iOS...

  • wow大秘境是什么(魔兽大秘境有什么玩的)

    wow大秘境是什么(魔兽大秘境有什么玩的)

    毫无疑问,这是一篇“明目张胆”的安利文章,我们要安利的对象不是市面上那些杂七杂八的游戏。值得为安利编辑的一定是游戏史上的经典,《魔兽世界》的名字一定在经典之列。经过十七年的运营,拥有数千万玩家的《魔兽世界》能称霸MMORPG十几年,无人能...

  • 洪荒之力是什么意思(洪荒之力到底是啥意思)

    洪荒之力是什么意思(洪荒之力到底是啥意思)

    在接受记者采访时,傅表示自己已经“用尽了洪荒之力”。之后很多媒体也争相用洪荒之力做头条,试图表达一个很硬的意思。其实洪荒之力与人无关。标题党之所以蜂拥而至,是因为它根本不知道什么是洪荒之力。那么“洪荒之力”到底是什么?洪水是指地球形成...

  • 适合小孩玩的游乐项目(适合小孩玩的游乐项目是什么)

    适合小孩玩的游乐项目(适合小孩玩的游乐项目是什么)

       今天给大家分享几个适合孩子玩的游乐项目的问题(适合孩子玩的游乐项目有哪些)。以下是小编对这个问题的总结。让我们看一看。1.泰空沙:太空沙能帮助儿童提升创造力,获得更多智慧与快乐。作为益智玩具,太空沙手感柔,具有良好的流动性,玩太空...

  • audio是什么意思(audio是什么意思车上的)

    audio是什么意思(audio是什么意思车上的)

       今天我想和大家分享一下关于音响是什么意思(车上的音响是什么意思)的问题。以下是这个问题的总结。希望能帮到你。让我们看一看。Audio是一个英文单词,有很多含义:Audio是一种压缩的数字声音格式在AU格式下的详细写法;是音频的单词...

  • 收益是什么(如何估算每月的收益)

    收益是什么(如何估算每月的收益)

    我是小文,奇谈怪论,定期分享行业动态,持续输出资讯,与右上角友友资源网一起努力!问大多数人Youyou.com每月挣多少钱,基本上就是一加一减去收入和支出的问题。这是典型会计中的收付实现制,不太准确。今天教你一招,让你的月收入更准确!首先...

  • 浮华是什么意思(浮华尘世的意思)

    浮华是什么意思(浮华尘世的意思)

    意思是人世间的生活虽然多姿多彩。充满各种情况、淫逸。没有根底、世界纷纷扰扰、有句话叫做、重要的是你对世界的认识及看法,追求情感、表面上动人而实际内容空。字华而不实,拼音fúhuá,字义华而不实,很美。虚荣,虚荣和财富。而忘记自己纯洁而被污...

  • 金坷垃是什么(金坷垃是什么东西)

    金坷垃是什么(金坷垃是什么东西)

       今天我想和大家分享一个关于什么是金蛤(什么是金蛤)的问题。以下是小编对这个问题的总结。让我们看一看。“黄金蟹”是一种号称由美国圣地亚哥研发,中国生产的肥料添加剂。它的流行是因为一个广为流传的金蟹三人组争夺金蟹的广告视频。由于广告效...

  • 周排行
  • 月排行
  • 年排行

精彩推荐