功能--图片懒加载

本文介绍了如何在HTML和JavaScript中使用懒加载技术,通过监测滚动事件动态更改图片的src地址,当图片进入视口时才加载,同时提到闭包的概念及其在实现中的作用,以及可能存在的内存优化问题。

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

原理

在图片出现在视口市更换默认图片的src地址

HTML代码

<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />
<img src="./0.jpg" />

js代码

function lazyload() {
    //获取图片列表
    const imagesList = document.getElementsByTagName("img");
    var length = imagesList.length; // 一共有多少张图片
    var n = 0; // n用来保存之前已经加载过的多少张图片,就可减少下面遍历的次数
    return function () {
        console.log("dddd");
        var clientHeight = document.documentElement.clientHeight; // 浏览器可视区域的高度
        var scrollTop = document.documentElement.scrollTop; // 页面被遮挡的高度
        console.log(n);
        for (let i = n; i < imagesList.length; i++) {
            console.log(n);
            if (imagesList[i].offsetTop < clientHeight + scrollTop) {
                if (imagesList[i].getAttribute("src") === "./0.jpg") {
                    //当该img的路径为'./loading.png'时才把图片的真实路径赋值给src
                    imagesList[i].src = `./${i + 1}.jpg`;
                }
                n++;
            } else {
                break;
            }
        }
    };
}
const init = new lazyload();
init();
window.addEventListener("scroll", init, false); // 监听页面滚动事件,执行lazyload函数。

小知识--闭包

概念

定义在函数内部的函数

能读取其他函数内部变量的函数

可以将函数内部和函数外部连接起来

用途

可以读取函数内部变量

让这些变量的值始终保持在内存中

缺点

内存占用大、可能会导致内存泄漏

会在父函数外部改变父函数内部变量的值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

煦炎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值