Promise与Class

本文深入浅出地讲解了Promise的基础概念,包括Promise实例化、then方法的使用、catch处理失败状态,并探讨了如何通过Class扩展Promise。重点介绍了回调函数中的不同返回值和错误处理策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Promise

基础理解:

 // 实例化promise对象
    const p = new Promise((resolve,reject)=>{
      setTimeout(()=>{
        let data = [1,2]
        // 将promise状态改为成功
        // resolve(data)

        let err = '状态为失败'
        reject(err)
      },3000)
    })

    // 调用promise中then方法,成功的状态进入then的value回调中,失败状态进入reason回调中
    // result-then方法的返回结果也是一个Promise对象,对象状态由回调函数的执行结果决定
      // 1.如果回调函数中返回的结果是 非Promise对象,状态为成功,返回值为对象的成功值。
    const result = p.then(value=>{
      console.log(value,"成功状态执行");
      // 没有return 就返回undefined
      
      // 1.非promise类型
      // return 'sdf'

      // 2.是promise类型
      return new Promise((r,j)=>{
        setTimeout(()=>{
          r('ok')
        },2000)
        // j('error')
      })

      // 3.抛出错误
      // throw new Error('出错啦')
    },reason=>{
      console.error(reason,'失败状态执行');
    }).then((value)=>{
      console.log(value)
      return new Promise((r,j)=>{
        setTimeout(()=>{
          r('ok3')
        },500)
        // j('error')
      })
    }).then((res)=>{
      console.log(res)
    })

    p.catch((err)=>{
      console.log(err,'err')
    })

扩展:

Class

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值