老师这样可以吗?

老师这样可以吗?

1
​<!DOCTYPE html><br><html lang="en"><br><br><head><br>    <meta charset="UTF-8"><br>    <meta http-equiv="X-UA-Compatible" content="IE=edge"><br>    <meta name="viewport" content="width=device-width, initial-scale=1.0"><br>    <title>Document</title><br></head><br><br><body><br>    <div></div><br>    <script><br>        const imgSrc = [<br>            'http://img1.sycdn.imooc.com/climg//5b16558d00011ed506000338.jpg',<br>            'http://img1.sycdn.imooc.com/climg//5b165603000146ca06000338.jpg',<br>            'http://img1.sycdn.imooc.com/climg//5b1656140001c89906000338.jpg']<br><br>        const londImg = url => {<br>            return new Promise((resolve, reject) => {<br>                const img = new Image();<br><br>                img.onload = () => {<br>                    resolve(img)<br>                };<br><br>                img.onerror = () => {<br>                    reject(new Error(`Counld not load image at${url.src}`))<br>                };<br><br>                img.src = url;<br>            })<br>        };<br><br>        const div = document.querySelector('div');<br><br>        for (let i = 0; i < imgSrc.length; i++) {<br>            londImg(imgSrc[i])<br>                .then(url => {<br>                    setTimeout(() => {<br>                        div.appendChild(url)<br>                    }, (i + 1) * 1000)<br>                });<br>        };<br>    </script><br></body><br><br></html><br>


正在回答

登陆购买课程后可参与讨论,去登陆

2回答

同学你好,这样写效果是对的,建议优化一下实现方案:

londImg返回的是promise对象,所以可以通过链式调用(不用循环),实现逐一加载出图片,如下:

http://img1.sycdn.imooc.com//climg/609758730929acc608650471.jpg

http://img1.sycdn.imooc.com//climg/60975938094772f710250644.jpg

解释说明:

http://img1.sycdn.imooc.com//climg/609759ee09dc350109770510.jpg

祝学习愉快!

  • 五维码 提问者 #1

    老师我理解了,但是要有很多图片的话,一个个写then的不是会很繁琐嘛

    2021-05-09 13:29:47
好帮手慕久久 2021-05-09 15:13:35

同学你好,如果图片非常多,那就不适合老师提供的写法了,毕竟一个个写then也很麻烦,此时可以考虑使用for循环批量处理。由于本题的目的是想让大家像老师那样实现(链式调用then),所以老师给你调了一下。

祝学习愉快!

问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师
插入代码