JS:图片懒加载

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        img {
            display: block;
            width: 150px;
            height: 150px;
            margin: 40px;
        }
    </style>
</head>
<body>
    <img a-src="./image/1.jpg" alt="">
    <img a-src="./image/2.jpg" alt="">
    <img a-src="./image/3.jpg" alt="">
    <img a-src="./image/4.jpg" alt="">
    <img a-src="./image/5.jpg" alt="">
    <img a-src="./image/6.jpg" alt="">
    <img a-src="./image/7.jpg" alt="">
    <img a-src="./image/1.jpg" alt="">
    <img a-src="./image/1.jpg" alt="">

    <script>
        // 获取全部的img标签
        var imgs = document.querySelectorAll('img')

        function show() {
            // 获取可视区域的高度
            var bomHeight = innerHeight
            // console.log(bomHeight)

            // 获取滚动条滚动高度
            // document.body.scrollTop: 兼容ie浏览器
            // document.documentElement.scrollTop: 获取浏览器滚动条的滚动高度
            var scrollHeight = document.documentElement.scrollTop || document.body.scrollTop

            // imgs[0].src = './image/1.jpg'
            // console.log(imgs)

            // 获取最后一张图片距离浏览器顶部的高度
            // console.log(imgs[8].offsetTop)

            for (var i = 0; i < imgs.length; i++) {
                // 浏览器滚动高度 + 可视区域高度 >= imgs[i].offsetTop(每张图片距离顶部的高度)
                if (scrollHeight + bomHeight >= imgs[i].offsetTop) {

                    // getAttribute: 获取元素的属性值
                    // console.log(imgs[i].getAttribute('a-src'))


                    // 如果满足条件,说明图片需要被加载
                    imgs[i].src = imgs[i].getAttribute('a-src')
                }
            }
        }

        // window.onload: 页面加载完成后立即执行

        window.onload = function () {
            show()
        }

        window.onscroll = function () {
            show()
        }

        // 连续赋值
        // window.onload = window.onscroll = function () {
        //     show()
        // }
    </script>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值