Promise异步回调

Promise异步回调

  1. Promise 是一个 构造函数,既然是构造函数, 那么,我们就可以 new Promise() 得到一个 Promise 的实例

  2. 在 Promise 上,有两个函数,分别叫做 resolve(成功之后的回调函数) 和 reject(失败之后的回调函数)

  3. 在 Promise 构造函数的 Prototype 属性上,有一个 .then() 方法,也就说,只要是 Promise 构造函数创建的实例,都可以访问到 .then() 方法

  4. Promise 表示一个 异步操作,每当我们 new 一个 Promise 的实例,这个实例,就表示一个具体的异步操作

  5. Promise创建的实例,是一个异步操作,那么,这个 异步操作的结果,只能有两种状态:

  • 状态1: 异步执行成功了,需要在内部调用成功的回调函数 resolve 把结果返回给调用者
  • 状态2: 异步执行失败了,需要在内部调用失败的回调函数 reject 把结果返回给调用者
  1. 由于 Promise 的实例,是一个异步操作,所以,内部拿到 操作的结果后,无法使用 return 把操作的结果返回给调用者, 这时候,只能使用回调函数的形式,来把成功或失败的结果,返回给调用者

  2. 我们可以在 new 出来的 Promise 实例上,调用 .then() 方法预先为 这个 Promise 异步操作,指定成功(resolve) 和 失败(reject) 回调函数

  3. 每当 new 一个 Promise 实例的时候,就会立即 执行这个 异步操作中的代码,并且会得到一个Promise实例

注意:这里 new 出来的 promise, 只是代表形式上的一个异步操作,具体异步操作要自定义

案例

const fs = require('fs')

//定义一个异步读取文件的函数,返回一个Promise对象
function getFileByPath(fpath) {
     
  return new Promise(function (resolve, reject) {
     
    fs.readFile(fpath, 'utf-8', (err, dataStr) => {
     
	//有异常就返回异常信息	
      if (err) return reject(err)
      resolve(dataStr)
    })
  })
}

//1.连续回调
//调用读取文件的函数,并初始化读取成功和失败的回调函数
// 如果,前面的 Promise 执行失败,我们不想让后续的Promise 操作被终止,可以为每个promise 指定失败的回调,
//并返回一个新的Promise对象
 getFileByPath('./files/11.txt')
  .then(function (data) {
     
    //正确读取的回调函数
    console.log(data)
    // 读取文件2,返回一个新的Promise对象,给.then回调使用
    return getFileByPath('./files/2.txt')
  }, function (err) {
     
     //读取文件抛出异常的回调函数
    console.log('这是失败的结果:' + err.message)
    // return 一个 新的 Promise
    return getFileByPath('./files/2.txt')
  })
  .then(function (data) {
     
    console.log(data)
    return getFileByPath('./files/3.txt')
  })
  .then(function (data) {
     
    console.log(data)
  })

//2.捕获异常
// catch 的作用:如果前面有任何的Promise 执行失败,则立即终止所有 promise 的执行,
//并马上进入 catch 去处理 Promise中 抛出的异常;
getFileByPath('./files/1.txt')
  .then(function (data) {
     
    console.log(data)
    // 读取文件2
    return getFileByPath('./files/22.txt')
  })
  .then(function (data) {
     
    console.log(data)
    return getFileByPath('./files/3.txt')
  })
  .then(function (data) {
     
    console.log(data)
  })
  .catch(function (err) {
      
    console.log('异常的处理信息:' + err.message)
  })

你可能感兴趣的:(前端,vue.js,es6,node.js,jquery)