当前位置: 首页 > wzjs >正文

夸克建站系统官网seo诊断站长

夸克建站系统官网,seo诊断站长,成人高考可以报考哪些大学,域名查询网ipPromise详解 文章目录 Promise详解1、异步操作,同步操作2、Promise3、Promise使用3.1.创建promise3.2.使用 Promise:1.then2.cath3.finally**静态方法**:resolve,reject,all,race,allSettled,any 1、异步操作,同步操作 异步操作是…

Promise详解

文章目录

  • Promise详解
      • 1、异步操作,同步操作
      • 2、Promise
      • 3、Promise使用
        • 3.1.创建promise
        • 3.2.使用 Promise:
          • 1.then
          • 2.cath
          • 3.finally
          • **静态方法**:resolve,reject,all,race,allSettled,any

1、异步操作,同步操作

异步操作是指在编程中,某个任务的执行不会立即完成,同时不会阻塞后续代码的执行。在异步操作中,程序可以继续运行,并在异步任务完成时得到通知并处理结果。

同步操作会阻塞程序的继续执行直到任务完成。

异步操作的作用:如果没有异步,那么每请求一个接口,页面都将不能被滑动,呈现出来就是一卡一卡的

回调函数是最基本的异步处理方式。在异步操作完成后,调用预先传入的函数。但是,会出现回调地狱。

2、Promise

Promise 是 JavaScript 的一个特性,它允许你在异步操作(如网络请求)完成后执行某些代码。它代表了一个将来才会知道结果的操作。解决回调地狱

Promise 可以处于以下三种状态之一:

pedding->初始状态:调用promise时,一开始就呈现出等待状态,遇到resolve或者reject之前,都处于这个状态,且可以改变,但如果确定了状态(fulfilled/reject),则结果将永远不变,不能再次修改

fulfilled->成功状态:在执行了resolve后,promise则会从pedding变成fulfilled,后续会进入.then 的回调函数中,在回调函数的第一个参数函数中可以获取到值

rejected->失败状态:在执行了reject后,promise状态会变成rejected,rejected函数传递的参数,可以在.then的第二个参数函数中获取的到,或者是在.catch获取到,但是如果程序上的错误,得通过.catch函数去拿到失败消息,在.then中是获取不了的

3、Promise使用

3.1.创建promise
let promise = new Promise((resolve, reject) => {// 异步操作if (/* 操作成功 */) {resolve(value); // 成功时调用} else {reject(error); // 失败时调用}
});
3.2.使用 Promise:
1.then
  • then():接收两个函数作为参数,第一个函数在 Promise 成功时调用,第二个在失败时调用。
promise.then(value => { /* 成功时的处理 */ },error => { /* 失败时的处理 */ }
);
2.cath
  • catch():用于捕获 Promise 中发生的错误。
promise.catch(error => { /* 错误处理 */ }
);
3.finally
  • finally():无论 Promise 最终状态如何都会执行。
promise.finally(() => {// 总是会执行的代码
});

链式调用:可以将多个 .then().catch() 串联起来,形成链式调用。

静态方法:resolve,reject,all,race,allSettled,any
  • Promise.resolve(value)

    • 创建一个立即解析的 Promise 对象,状态为 fulfilled
    • 等同于 new Promise(resolve => resolve(value))
  • Promise.reject(reason)

    • 创建一个立即拒绝的 Promise 对象,状态为 rejected
    • 等同于 new Promise((_, reject) => reject(reason))
  • Promise.all(iterable)

    • 接收一个 Promise 可迭代对象(如数组)
    • 当所有 Promise 都成功时返回一个包含所有结果的数组
    • 如果有一个 Promise 失败,则立即拒绝并返回第一个失败的原因
  • Promise.race(iterable)

    • 接收一个 Promise 可迭代对象
    • 返回第一个完成(无论成功或失败)的 Promise 的结果或原因
  • Promise.allSettled(iterable)

    • 接收一个 Promise 可迭代对象

    • 等待所有 Promise 完成(无论成功或失败)

    • 返回一个包含每个 Promise 结果的对象数组,每个对象有 status(state表示promise的状态:resolve和rejected)和 value (value代表的是promise传递的值)或 reason 属性

    • var p1 = new Promise((resoleve, reject) => {setTimeout(() => {console.log("----打印:p1");resoleve("p1--3000");}, 3000);
      });let p2 = new Promise((resoleve, reject) => {setTimeout(() => {reject("p2--1000");}, 1000);
      });let p4 = new Promise((resolve, reject) => {throw new Error("抛出错误");
      });Promise.allSettled([p1, p2, p4]).then((result) => {console.log("----打印:result", result);}).catch((err) => {console.log("----打印:", err); //不执行});//执行结果
      // ----打印:p1
      // ----打印:result [
      //   { status: 'fulfilled', value: 'p1--3000' },
      //   { status: 'rejected', reason: 'p2--1000' },
      //   {
      //     status: 'rejected',
      //     reason: Error: 抛出错误
      //   }
      // ]
      
  • Promise.any(iterable)

    • 接收一个 Promise 可迭代对象
    • 返回第一个成功的 Promise 的结果
    • 如果所有 Promise 都失败,则返回一个 AggregateError 包含所有失败原因
  • Promise.any(iterable)

    • 接收一个 Promise 可迭代对象
    • 返回第一个成功的 Promise 的结果
    • 如果所有 Promise 都失败,则返回一个 AggregateError 包含所有失败原因
http://www.dtcms.com/wzjs/507504.html

相关文章:

  • 专业网站建设制作价格设计网站都有哪些
  • 做网站首选科远网络青岛网络优化厂家
  • 上海网站建设sheji021杭州seo网站优化
  • 怎么用网站挂QQapp数据分析软件
  • 固始网站建设流量主广告点击自助平台
  • 门户类网站是什么意思如何引流推广
  • 装修网站应该怎么做房地产新闻最新消息
  • 做b2c网站需要多少钱qianhu微建站
  • 娄底网站制作公司网站建设平台
  • 软件公司网站模板图片西安seo培训学校
  • 天津做网站哪家公司好网络营销有哪些特点
  • 做类似慕课网的网站要多少钱上海百度推广排名优化
  • 兴宁市住房和城乡建设部网站旅行网站排名前十名
  • 网站pv访问量统计怎么做农村电商平台
  • 打开网站说建设中是什么问题?上海疫情突然消失的原因
  • 观音桥网站建设网站建设百度浏览器官网下载
  • 哈尔滨最新疫情轨迹公布而的跟地seo排名点击软件
  • 网站流量提供商市场营销方案
  • 织梦cms发布侵权网站清单百度关键词优化大师
  • 西宁做网站制作的公司哪家好百度网盘官网
  • 有赞微商城下载搜索引擎优化英文简称
  • 工信部网站 备案网站推广四个阶段
  • 网站流量攻击软件chrome官网
  • 山东做网站费用保定seo推广外包
  • 做网站犯法了 程序员有责任吗专业黑帽seo
  • 互联网服务杭州seo网站建设
  • 青海微信网站建设网站要怎么创建
  • 自己建设一个网站步骤南昌seo排名优化
  • 武汉网站推广优化公司南昌seo排名扣费
  • 有谁知道知乎网站是谁做的拓客软件排行榜