Promise 的简单介绍
-
Promise的概述
promise 是 es6 提出的一个比传统回调事件的写法更加合理更加强大
-
Promise的状态
resolve : 将 Promise的状态设置为 fullfilled (已成功) reject: 将 Promise 的状态设置为 rejected (已失败) Promise 的状态 一旦改变, 不可更改
-
Promise对象的创建方式
a) new Promise((resolve, reject) => {} ) : promise 的状态由回调函数来进行切换 b) Promise.resolve(data) : 快速构建一个 fulfilled 状态的 promise c) Promise.reject(data) : 快速构建一个 rejected 状态的 promise\
let p = Promise.resolve("ok")
//不同的方法
// let p = new Promise((resolve, reject) => {
// resolve("ok")
// })
p.then(res => {
return Promise.reject("error")
}).catch(error => {
console.error(error)
})
-
Promise#then 方法的特点
then 支持两个回调函数 第一个回调函数,代表 Promise 状态为 fulfilled 执行的回调 第二个回调函数, 代表 promise 状态为 rejected 执行的回调
-
Promise 链式调用
then : 1. 处理 承诺 已完成的 业务 2. 更改 返回的 新的 promise 对象的状态 then 方法会返回一个 新的 promise 对象 a) then 方法的回调函数如果能被执行, 新的 promise 对象 状态由 回调函数 确定 1) 如果回调函数产生异常, 则返回 rejected 状态的 promise 2) 如果回调函数 没有 return ,则 返回 fulfilled 状态,并将 undefined 作为参数传给新的promise 3) 如果回调函数 return 普通数据、则将 普通数据 作为 resolve 的 参数传给新的 promise 4) 如果回调函数 return 一个 promise 对象,则then 返回的新的promise 对象状态和 return 的promise对象状态完全一致 b) then 方法的回调函数如果不能执行,新的 promise 对象 和 调用 then 方法的 promise状态 完全一致
-
Promise.resolve 传入的参数类型
Promise.resolve(arg) 快速的创建一个状态为 fulfilled的 promise arg 参数的类型满足以下条件 1) arg是一个普通数据,会构建一个 fulfilled状态的 promise,并将 arg 的值 作为 resolve的参数 2) arg 是 undefined, 会将 undefined 作为 resolve的参数,并返回 fulfilled状态的 promise 3) arg 是一个 thenable(某个对象中有 then 方法) 对象, 那么 会直接执行 then 方法, 返回的promise对 象状态由 then函数来确定 4) arg 是一个promise 对象, 那么会返回一个 和 arg promise对象状态完全一致的 promise
let p = new Promise((resolve, reject)=> {
reject("ok")
})
let p2 = Promise.resolve(p)
setTimeout(function(){
console.log(p2)
})
Object.is(NaN, NaN)