JS 图片懒加载

 

所谓懒加载就是在图片进入 *可视区域* 前,用 *同一张* 图片作为图片的 src 属性值,这样可减少请求及带宽。懒加载的重点是:判断元素是否进入可视区域?

元素距离文档顶部高度(这个值固定不变) - 整个文档被滚动高度(浏览器滚动条向下滚动高度) <= 可视高度,表示元素进入可视区域

Demo:

复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>懒加载</title>
    <style type="text/css">
        * { padding: 0; margin:0; }
        img { display: block; height: 171px;}
    </style>
</head>
<body>
    <img src="../site/images/users_avatar/user1.png" data-loaded="1">
    <img src="../site/images/users_avatar/user2.png" data-loaded="1">
    <img src="../site/images/users_avatar/user3.png" data-loaded="1">
    <img src="../site/images/users_avatar/user4.png" data-loaded="1">
    <img src="../site/images/users_avatar/user5.png" data-loaded="1">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
    <img src="../site/images/loading-1.gif" data-loaded="0">
</body>
<script type="text/javascript">
    window.onload = function () {
        window.onscroll = function () {
            // 重点:判断元素是否进入可视区域?
            // 元素距离文档顶部高度(这个值固定不变)减去
            // 整个文档被滚动高度(浏览器滚动条向下滚动高度)
            // 小于等于可视高度,表示元素进入可视区域
            var images = document.querySelectorAll('img');
            var scroll_h = document.documentElement.scrollTop;
            var visual_h = window.innerHeight;
            // 实现等待加载效果
            setTimeout(function() {
                for (var i = 5; i < images.length; i++) {
                    if (images[i].getAttribute('data-loaded') === '0'
                        && images[i].offsetTop - scroll_h <= visual_h
                        ) {
                            images[i].src = "../site/images/users_avatar/user" + (i + 1) + ".png";
                            images[i].setAttribute('data-loaded', '1');
                    }
                }
            }, 550);
        }
    }
</script>
</html>
复制代码

 

posted @   gentsir  阅读(401)  评论(1编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
点击右上角即可分享
微信分享提示