JavaScript中Promise详解

一. Promise是什么,解决什么问题

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

  • 简单来说,Promise是一个容器,里面包含着一个异步操作的结果
  • 从语法上来说,promise(小写的p)是一个对象,从它可以获取异步操作的最终状态
  • 而Promise是一个构造函数,自己身上由reject resolve all方法,原型上有then catch方法

Promise有三种状态,pending 初始态,fulfilled 成功状态,rejected失败状态,只有异步操作的结果可以决定当前是哪一种状态,其他任何操作都无法改变这个状态。

Promise的状态一旦改变,就不会再变,任何时候都可以得到这个结果,状态不可以逆,只能由 pending变成fulfilled或者由pending变成rejected

首先来了解一下回调函数

/*
  回调函数callback
    +什么是回调函数
      =>定义:把 A函数当作参数传递到 B函数内部,在 B函数内部以形参的方式调用 A函数
      =>这种函数的调用方式,我们叫做回调函数(ca11back)
*/
function A(cb) {
  console.log('a')
  cb(new Date())
}

function B(cb) {
  console.log('b')
  cb(function (res) {
    console.log(res)
  })
}

B(A)

Promise主要解决的问题

  • 回调地狱:第一个回调的结果,被内层的第二个回调所需要
  • promise可以支持多个并发的请求,获取并发请求中的数据
  • 这个promise可以解决异步的问题,本身不能说promise是异步的

二. Promise基础语法

/*
  Promise的语法
  + Promise 是 ES6 内置的构造函数
  + 语法:new Promise(function(){你要执行的异步的事情 })
    => 实例化的时候,这个函数接收两个参数
    => resolve,reject
  + 语法:
    =>实例化对象身上由两个方法
    1. then()
      -> promise对象.then(function(){})
    2. catch()
      -> promise对象.catch(function(){})
    => then方法的函数传递给了实例化的 resolve
    => catch方法的函数传递给了实例化的 reject
*/

const p = new Promise(function (resolve, reject) {
  // resolve是成功的回调函数 当你书写resolve()的时候,实际上是在调用then里面的函数
  // reject是失败的回调函数 当你书写reject()的时候,实际上是在调用catch里面的函数
  ajax({
    url: './server/a.php',
    dataType: 'json',
    success(res) {
      resolve(res)
    },
    error(err) {
      reject(err)
    }
  })
})

// 在 new Promise里面做一些回调的事情
// 将回调的结果转移到外面 then catch中
// 在 promise中做一件异步的事情,把结果放在外部的函数中去执行
p.then(function (res) { console.log('我执行了', res) })
p.catch(function (err) { console.log('我失败了', err) })

三. Promise进阶语法

/*
    Promise的进阶语法
      + 当你在一个 promise对象的 then里面返回一个新的 promise对象
      + 你可以在这个 then的后面继续来一个 then接收第一个 then里面 promise对象的结果
*/

new Promise(function (resolve, reject) {
  ajax({
    ur1: './server/a.php',
    dataType: 'json',
    success(res) {
      resolve(res)
    }
  })
})
.then(function (res) {
  console.log('需求1:', res)
  return new Promise(function (resolve, reject) {
    ajax({
      ur1: './server/b.php',
      data: res,
      dataType: 'json',
      success(res) {
        resolve(res)
      }
    })
  })
})
.then(function (res) {
  console.log('需求2:', res)
  return new Promise(function (resolve, reject) {
    ajax({
      url: './server/b.php',
      data: res,
      dataType: 'json',
      success(res) {
        resolve(res)
      }
    })
  })
})
.then(function (res) {

四. Promise.all的用法

const p1 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('结果1')
  }, 1000);
})
const p2 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('结果2')
  }, 1000);
})
const p3 = new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve('结果3')
  }, 1000);
})

// 三个都成功则成功,只要有一个失败就失败
// 成功时则会返回一个数组
Promise.all([p1, p2, p3]).then(res => {
  console.log(res);
})
  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值