Promise对象和任务队列

本文介绍了Promise对象的两个特点,即状态不可变和提供统一接口。Promise简化了异步编程,通过then方法指定回调。文章还阐述了JavaScript的事件队列、事件循环(Event Loop)的概念,解释了同步任务与异步任务的执行顺序,以及setTimeout如何工作。
摘要由CSDN通过智能技术生成

Promise对象的两个特点

  1. 对象的状态不受外界影响。Promise对象代表一个异步操作,有三种状态:pending(进行中)fulfilled(已成功)rejected(已失败)
  2. 一旦状态改变,就不会再变。状态的改变有两种可能:从pending到fulfilled和从pending变为rejected。

优点

有了Promise对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise对象提供统一的接口,使得控制异步操作更加容易。

基本用法

下面是一个Promise实例

const promise = new Promise(function(resolve, reject) {
   
  // ... some code
  if (/* 异步操作成功 */){
   
    resolve(value);
  } else {
   
    reject(error);
  }
});

Promise构造函数接受一个函数作为参数,该函数的两个参数分别为resolve和reject。resolve函数的作用是将Promise对象的状态由pending转化为fulfilled。reject函数的作用是将Promise对象的状态由pending转化为rejected。

Promise实例生成之后,可以使用then方法分别指定resolved状态和rejected状态的回调函数,其中rejected状态的回调函数是可选的。

promise.then(function(value) {
   
  // success
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值