彻底搞懂Promise

Promise

手写Promise推荐
视频讲解(不是很全面,但是讲的不错)
文字讲解(较为全面)

从语法上说,Promise 是一个对象,从它可以获取异步操作得到的消息。

console.log(
  typeof new Promise((r) => {
   
    r();
  })
); //>> 'object'

创建Promise对象

Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolvereject。它们是两个函数,由 JavaScript 引擎提供,不用自己部署。

  • resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;
  • reject函数的作用是,将Promise对象的状态从“未完成”变为“失败”(从 pending 变为 rejected),在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。

注:如果不传参,这个Promise对象就会一直保持pending状态。

let promise = new Promise(() => {
   });
promise.then((res) => console.log(res)); //没有输出

then

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

promise.then(function(value) {
   
  // success
}, function(error) {
   
  // failure
});
// 相当于
promise.then(function(value
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值