关于promise的那些问题

我们在项目中经常会用Promise执行一些异步操作,但我们真的了解Promise么?Promise有哪些api呢?如何手写Promises呢?带着这些疑问笔者整理了一些有关的Promise的知识

什么是 promise

promise 是一种异步编程解决方案,有三种状态,pending(进行中),resolved(已完成),rejected(已失败),当 promise 的状态由 pending 转为 resolved 或 rejected 时,会执行对应的方法。状态一经改变就无法返回

promise 能解决什么问题

  1. 回调地狱 多个回调相互嵌套导致代码维护困难,代码臃肿
  2. 支持多并发的请求
  3. 解决可读性差的代码问题
  4. 解决代码的信任问题,promise只有一次决议

除了promise 还有什么其他的解决方法

  • async await
  • Generator
  • setTimeout

setTimeout

setTimeout的真正作用是,在“任务队列”的现有事件的后面再添加一个事件,规定在指定时间执行某段代码。setTimeout添加的事件,会在下一次Event Loop执行。

Generators/yield

Generators与传统函数不同,Generator最大的特点是可以控制函数的执行。这里附上一段代码就能理解

function* foo(x) {
  let y = 2 * (yield (x))
  let z = yield (y / 3)
  return (x + y + z)
}
let it = foo([1, 2])
console.log(it.next()); //6
// console.log(it.next(12));//将上一个执行结果作废 12赋值上一个yield返回的值
console.log(it.next());

async/await

async/await是基于Promise实现的,所以也是非阻塞的。async/await看起来更加简洁,而且async/await让异步代码看起来更像是同步代码。

promise 的使用

  1. 创建promise实例对象
  2. 用then方法指定resolved状态和rejected状态的回调函数
  3. 用catch方法指定rejected状态的回调函数

promise 的缺点

  1. promise一旦执行,无法中途取消
  2. promise 的错误无法在外部捕捉到
  3. 外部很难检测 promise 内部的运行

promise的常用api

Promise.then():得到异步任务的正确结果

Promise.catch():获取异常信息

Promise.finally():无论成功还是失败都会执行

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

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

一道Promise问题

红灯3秒亮一次,绿灯1秒亮一次,黄灯2秒亮一次;如何让三个灯不断交替重复亮灯?(用Promise实现)

function red() {
   
    console.log("red");
}
function green() {
   
    console.log("green");
}
function yellow() {
   
    console.log("yellow");
}
const light = function (timer, cb) {
   
    return new Promise(resolve => {
   
        setTimeout(
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中,setInterval和Promise执行顺序是根据事件循环机制来确定的。事件循环是JavaScript用来处理异步操作的一种机制。首先,让我们来了解一下事件循环的基本原理。 JavaScript是单线程执行的,意味着同时只能执行一段代码。当某一段代码正在执行时,其他任务必须等待。这种执行方式也被称为"阻塞式执行"。JavaScript中的任务队列用于存储等待执行的任务。一旦当前任务执行完毕,事件循环会从任务队列中取出下一个任务并执行。 对于setInterval和Promise执行顺序问题,具体的执行顺序取决于它们被添加到任务队列的时间和优先级。根据引用的说明,事件循环的优先级从高到低依次是:主代码块 > setImmediate > MessageChannel > setTimeout / setInterval。 如果存在多个setInterval和Promise任务,它们会根据优先级和添加到任务队列的顺序依次执行。setInterval的任务会按照指定的时间间隔重复执行,而Promise的任务则会在其他任务执行完毕后被执行。 需要注意的是,Promise中的then方法是异步执行的,它会在当前任务执行完毕后被添加到任务队列中,等待执行。因此,即使是在Promise的then方法中使用了setTimeout,它也会按照任务队列的顺序被执行。具体的执行顺序可能因为任务队列中的任务数量和优先级而有所不同。 综上所述,setInterval和Promise执行顺序是根据它们被添加到任务队列的时间和优先级来确定的。具体的执行顺序可以通过事件循环机制来理解。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [js 关于setTimeout和Promise执行顺序问题](https://blog.csdn.net/zlzbt/article/details/100577954)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JavaScript--Promise执行顺序](https://blog.csdn.net/qq_45633813/article/details/126781947)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值