Promise对象及常用方法

Promise对象

Promise 对象代表了未来将要发生的事件,开创一个异步线程,用来传递异步操作的消息。

Promise 对象有以下两个特点:

1.对象的状态不受外界影响。Promise 对象代表一个异步操作,有三种状态:
  pending: 初始状态,不是成功或失败状态
  fulfilled: 意味着操作成功完成
       rejected: 意味着操作失败
2.只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态。
   Promise 对象的状态改变,只有两种可能:
       1.从 Pending 变为 Resolved 
       2.从 Pending 变为 Rejected。
只要这两种情况发生,状态就凝固了,不会再变了,会一直保持这个结果。就算改变已经发生了,再对 Promise 对象添加回调函数,也会立即得到这个结果。

Promise 优缺点:

   优点:
       Promise 对象提供统一的接口,使得控制异步操作更加容易,避免了层层嵌套的回调函数。
   缺点:
       1.无法取消 Promise,一旦新建它就会立即执行,无法中途取消。
       2.如果不设置回调函数,Promise 内部抛出的错误,不会反应到外部
       3.当处于 Pending 状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)

创建Promise

复制代码
let prom = new Promise((resolve, reject)=>{
    // 异步处理,处理结束后调用resolve或reject
    // 当异步代码执行成功时,我们才会调用resolve(...), 当异步代码失败时就会调用reject(...)
    // 在本例中,我们使用setTimeout(...)来模拟异步代码,实际编码时可能是XHR请求或是HTML5的一些API方法.
    setTimeout(()=>{
        resolve("成功!"); //代码正常执行!
    }, 250);
})

prom.then((result)=>{
    // result的值是上面调用resolve(...)方法传入的值.
    // result参数不一定非要是字符串类型,这里只是举个例子
    console.log("result:" + result)     // 打印结果: result:成功!
})
复制代码

Promise.then() 

对于已经实例化过的 promise 对象可以调用 promise.then() 方法,传递 resolve 和 reject 方法作为回调。
  promise.then() 是 promise 最为常用的方法。
  promise.then(onResolved, onRejected)
复制代码
function p(){
    let a = 1
    return new Promise(resolve => {
        resolve(a)    // 将参数a传递给then()
    })
}
p().then((val) => {
    console.log("a:"+val)   // a:1
})
复制代码

Promise.then()可以采用链式写法

Promise.prototype.then 方法返回的是一个新的 Promise 对象,因此可以采用链式写法

例:

复制代码
function p(){
    let a = 1
    return new Promise(resolve => {
        resolve(a)    // 将参数a传递给then()
    })
}

p().then((val) => {
    return val+1
}).then((val) => {
    console.log(val + 2)  // 4
})
复制代码

 Promise.Catch()捕捉错误

 Promise.Catch()用于指定发生错误时的回调函数

Promise 对象的错误具有"冒泡"性质,会一直向后传递,直到被捕获为止。也就是说,错误总是会被下一个 catch 语句捕获。

复制代码
function p(){
    let a = 1
    return new Promise(resolve => {
        resolve(a)    // 将参数a传递给then()
    })
}

p().then((val) => {
    console.log(val + 2)  // 4
}).catch((error) => {
    console.log("error:", error)
})
复制代码

Promise.all方法

Promise.all 方法用于将多个 Promise 实例,包装成一个新的 Promise 实例

var p = Promise.all([p1,p2,p3]);

上面代码中,Promise.all 方法接受一个数组作为参数,p1、p2、p3 都是 Promise 对象的实例。

(Promise.all 方法的参数不一定是数组,但是必须具有 iterator 接口,且返回的每个成员都是 Promise 实例。)

p 的状态由 p1、p2、p3 决定,分成两种情况:

  • 只有p1、p2、p3的状态都变成fulfilled,p的状态才会变成fulfilled,此时p1、p2、p3的返回值组成一个数组,传递给p的回调函数。
  • 只要p1、p2、p3之中有一个被rejected,p的状态就变成rejected,此时第一个被reject的实例的返回值,会传递给p的回调函数。

例:

Promise.all()返回一个Promise返回值的数组

复制代码
function createProcess(str){
    return new Promise(resolve => {
        setTimeout(() => {
            resolve(str)
        }, 1000 )
    })
}

let p0 = createProcess("0")
let p1 = createProcess("1")
let p2 = createProcess("2")
let p3 = createProcess("3")

let promises = [p0, p1, p2, p3]

Promise.all(promises).then(pro => {
    console.log(pro)        // [ '0', '1', '2', '3' ]
})
复制代码

 

posted @   邢韬  阅读(455)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
点击右上角即可分享
微信分享提示