老师这样可以吗?

老师这样可以吗?

​<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>

<body>
<div></div>
<script>
const imgSrc = [
'http://img1.sycdn.imooc.com/climg//5b16558d00011ed506000338.jpg',
'http://img1.sycdn.imooc.com/climg//5b165603000146ca06000338.jpg',
'http://img1.sycdn.imooc.com/climg//5b1656140001c89906000338.jpg']

const londImg = url => {
return new Promise((resolve, reject) => {
const img = new Image();

img.onload = () => {
resolve(img)
};

img.onerror = () => {
reject(new Error(`Counld not load image at${url.src}`))
};

img.src = url;
})
};

const div = document.querySelector('div');

for (let i = 0; i < imgSrc.length; i++) {
londImg(imgSrc[i])
.then(url => {
setTimeout(() => {
div.appendChild(url)
}, (i + 1) * 1000)
});
};
</script>
</body>

</html>


正在回答

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

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下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

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