Promise(resolve,reject)的基本使用

什么是Promise?

Promise是一个构造函数,其原型上有 then、catch方法,还有reslove,reject等静态方法。通过创建Promise实例,可以调用Promise.prototype上的then、catch方法。

Promise的作用

MDN对Promise的描述:

Promise能够将异步操作最终成功返回值或者失败原因和相应的处理程序关联起来。 这样使得异步方法可以像同步方法那样返回值:异步方法并不会立即返回最终的值,而是会返回一个 Promise,以便在未来某个时候把值交给使用者。

简单来说就是:使异步方法也能够根据其操作最终结果是成功还是失败的具体情况绑定不同的后续处理事件

Promise的使用

一个 Promise 必然处于以下几种状态之一:(其中fulfilled状态和rejected状态也称作settled状态)

1、pending : 初始状态,既没有被兑现,也没有被拒绝。

2、fulfilled : 意味着操作成功完成。

3、rejected : 意味着操作失败。

处于初始状态(pending)的Promise,最终要么成功(fulfilled )要么失败(rejected ),无论成功还是失败,通过then方法调用相关处理程序。

在实例化Promise的时候需要传入 resolve 和 reject 这两个函数作为其参数,当异步任务顺利完成且返回结果值时,会调用 resolve 函数;而当异步任务失败且返回失败原因(通常是一个错误对象)时,会调用reject 函数。

then函数中有两个参数,如下:

promise.then(successCallback, failureCallback);

第一个参数是状态变为成功后应该执行的回调函数,第二个参数是状态变为失败后应该执行的回调函数。

具体使用例子:

let testPromise = new Promise((resolve,reject)=>{
        setTimeout(function(){
           // resolve('成功!') //状态为成功,传的参数作为then函数中成功函数的实参
           reject('失败!') //状态为失败,传的参数作为then函数中失败函数的实参
        }, 1000);
});

testPromise.then((data)=>{
    console.log('success'+data)
},(err)=>{
    console.log('fail'+err)
})    

打印结果 "fail失败!"

其中 data 和 err 就是上面调用 resolve 和 reject 方法传入的值。

Promise链式调用

由上面例子可以知道 Promise链式调用可以实现多个异步操作连续执行,且上个操作执行成功后,执行下一个操作,并包含上个操作返回的结果。

因此链式调用可以很好解决 回调地狱 问题,避免了一层又一层的嵌套,虽然代码量可能没有减少,但是代码结构更加清晰、易读。

回调地狱例子:

toDoA(function(result) {
  toDoB(result, function(newResult) {
    toDoC(newResult, function(finalResult) {
      console.log('最终结果: ' + finalResult);
    }, failureCallback);
  }, failureCallback);
}, failureCallback);

使用链式回调:

toDoA()
.then(result => toDoB(result))
.then(newResult => toDoC(newResult))
.then(finalResult => {
  console.log(`'最终结果': ${finalResult}`);
})
.catch(failureCallback);

catch(failureCallback)可以看做then(null,failureCallback)

更多使用方法可以参考MDN

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Promise是一种JavaScript编程语言中的对象,用于异步操作的处理。在Promise对象中,resolve和reject是两个重要的方法。 resolve方法是Promise对象执行成功时所调用的方法。当Promise对象成功执行后,它会返回一个包含异步操作结果的值,并且调用resolve方法将其传递给回调函数。 reject方法是Promise对象执行失败时所调用的方法。当Promise对象执行失败时,它会返回一个包含错误信息的值,并且调用reject方法将其传递给回调函数。 正确,Promise对象是一种用于异步编程的JavaScript对象。在创建一个Promise对象时,我们可以定义一个异步操作,并且通过调用resolve或reject方法来决定异步操作的结果。 resolve方法通常用于异步操作成功时,它将传递异步操作的结果给回调函数。而reject方法则通常用于异步操作失败时,它将传递错误信息给回调函数。 一旦Promise对象执行resolve或reject方法,就会触发Promise对象的状态变化。如果resolve方法被调用,Promise对象的状态将变为resolved;如果reject方法被调用,Promise对象的状态将变为rejected。这些状态变化将触发相关的回调函数执行,从而让我们可以在异步操作完成后获取结果或者处理错误。PromiseJavaScript 中一种用于处理异步操作的对象。当使用 Promise 时,你可以调用 Promise 对象的 then() 方法来注册成功时的回调函数,或者调用 catch() 方法来注册失败时的回调函数。 Promise 对象有两个重要的方法 resolve() 和 reject(),它们分别用于在 Promise 对象成功或失败时进行处理。具体来说: - resolve() 方法将 Promise 对象的状态从“未完成”变为“成功”,并将成功的结果传递给 then() 方法中注册的回调函数。 - reject() 方法将 Promise 对象的状态从“未完成”变为“失败”,并将失败的原因传递给 catch() 方法中注册的回调函数。 下面是一个简单的示例,展示了如何使用 Promise 对象、resolve() 方法和 reject() 方法来处理异步操作: ``` function fetchData() { return new Promise((resolve, reject) => { // 异步操作 if (/* 异步操作成功 */) { resolve('数据获取成功'); } else { reject('数据获取失败'); } }); } fetchData() .then((result) => { console.log(result); // 输出:'数据获取成功' }) .catch((error) => { console.error(error); // 输出:'数据获取失败' }); ``` 在上面的示例中,fetchData() 函数返回一个 Promise 对象,并在异步操作成功时调用 resolve() 方法,传递成功的结果。在异步操作失败时,调用 reject() 方法,传递失败的原因。 然后,在调用 fetchData() 函数后,我们通过链式调用 then() 方法和 catch() 方法来注册成功和失败的回调函数。如果异步操作成功,则 then() 方法中的回调函数会被调用,并传递成功的结果;如果异步操作失败,则 catch() 方法中的回调函数会被调用,并传递失败的原因。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mmsmd

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值