双重for循环解决异步请求

前几天就写到了canvas绘制地图,但是在计算出地理范围之后,在请求对应图片和绘制的过程中,遇到了异步的问题。一直没解决,最后花了20块大洋才解决了。下面记录一下如何使用es6语法来解决异步。传统的回调方式解决的方法后续补上。

  //开始绘制
    let disTop=0;
     function draw(i1,j1) {
        return new Promise((resolve,reject) =>{
            disTop=i1*256;
           
            var img = new Image();
            img.src = `https://c.tile.openstreetmap.org/${zoom}/${i1}/${j1}.png`;
            img.οnlοad=function(){
                console.log("绘制"+j1*256,disTop)
                ctx.drawImage(img, disTop,j1*256);
                resolve()

            }
        })


    }
    (async function () {
        for(let i=0;i<=fixedTileLeftTopNumX;i++){
            for(let j=0;j<=fixedTileLeftTopNumY;j++){
               await draw(i,j)
            }
        }

    })()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值