Promise总结(promise 是什么?有哪些状态和参数?如何使用?)

Promise 是什么?

Promise 是异步编程的一种解决方案:

  1. 主要用于异步计算
  2. 可以将异步操作队列化,按照期望的顺序执行,返回符合预期的结果
  3. 可以在对象之间传递和操作 promise,帮助我们处理队列

Promise的参数是什么?

Promise接受一个「函数」作为参数,该函数的两个参数分别是resolvereject。这两个函数就是就是「回调函数」

  • resolve函数的作用:在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;
  • reject函数的作用:在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。

Promise的三个状态是什么?

  1. pending[待定]初始状态
  2. fulfilled[实现]操作成功
  3. rejected[被否决]操作失败

当 promise 状态发生改变,就会触发 then()里的响应函数处理后续步骤; promise 状态一经改变,不会再变。

Promise 对象的状态改变,只有两种可能: 从 pending 变为 fulfilled。
从 pending 变为 rejected。
这两种情况只要发生,状态就凝固了,不会再变了。

Promise如何使用?

在 ES6 中,可以使用三种办法创建 Promise 实例(对象)

  1. 构造方法
let promies = new Promise((resolve, reject) => {
 resolve(); //异步处理 
});

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

  1. 通过 Promise 实例的方法,Promise#then 方法返回的也是一个 Promise 对象
promise.then(onFulfilled, onRejected);
  1. 通过 Promise 的静态方法,Promise.resolve()Promise.reject()
var p = Promise.resolve();
p.then(function(value) {
 console.log(value); 
});
  • 8
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Promise是一种用于处理异步操作的JavaScript对象。它可以用来解决传统回调函数带来的回调地狱问题,使异步代码更加可读、可维护。 Promise有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)。当异步操作执行成功时,Promise状态从pending变为fulfilled;当异步操作执行失败时,状态从pending变为rejected。一旦状态改变,就会触发对应的回调函数。 使用Promise处理异步操作的一般步骤如下: 1. 创建一个Promise对象,通过new关键字实例化。 2. 在Promise对象的构造函数中传入一个执行器函数,该函数接受两个参数:resolve和reject。resolve函数用于将Promise状态从pending变为fulfilled,并传递异步操作的结果;reject函数用于将Promise状态从pending变为rejected,并传递错误信息。 3. 在执行器函数中编写异步操作的逻辑,当异步操作执行成功时调用resolve函数,传递操作结果;当异步操作执行失败时调用reject函数,传递错误信息。 4. 通过调用Promise对象的then方法可以注册成功回调函数,通过调用catch方法可以注册失败回调函数。这些回调函数会在异步操作执行成功或失败时被触发,并接收到相应的结果或错误信息。 下面是一个使用Promise处理异步操作的示例代码: ```javascript function fetchData() { return new Promise((resolve, reject) => { // 模拟异步操作 setTimeout(() => { const data = '异步操作的结果'; if (data) { resolve(data); // 异步操作成功,将状态改为fulfilled,并传递结果 } else { reject('异步操作失败'); // 异步操作失败,将状态改为rejected,并传递错误信息 } }, 2000); }); } fetchData() .then(result => { console.log('异步操作成功:', result); }) .catch(error => { console.error('异步操作失败:', error); }); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值