Promise 简单应用


// Promise 解决 callback hell 问题

// load img
function loadImage(src){
  return new Promise((resolve,reject)=>{
    const img = document.createElement("img")
    img.onload=()=>{
      resolve(img)
    }
    img.onerror=()=>{
      const err = new Error(`图片加载失败 ${src}`)
      reject(err)
    }
    img.src=src
  })
}
// 加载一个图片事例

// const url = "https://www.apple1.com.cn/v/mac/home/ba/images/overview/hero/dark/m1_icon__fiwfgl7tngya_medium_2x.jpg"
// loadImage(url).then(img=>{
//   console.log(img.width)
//   return img
// }).then(img=>{
//   console.log(img.height)
// }).catch(ex=>console.error(ex))

// 分批加载两个
const url1 = "https://www.apple.com.cn/v/mac/home/ba/images/overview/hero/dark/m1_icon__fiwfgl7tngya_medium_2x.jpg"
const url2 ="https://www.apple.com.cn/v/mac/home/ba/images/overview/hero/dark/macbook_pro_13__ft1pc3lqwd6y_medium.jpg"

loadImage(url1).then(img=>{
  console.log(img.width)
  return img //普通对象
}).then(img=>{
  console.log(img.height)
  return loadImage(url2) //Promise 实例
}).then(img=>{
  console.log(img.width)
  return img
}).then(img=>{
  console.log(img.height)
}).catch((ex)=>console.error(ex))




 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值