如何实现一个图片懒加载

1、页面一加载就只显示四张图片

 2、随着滚轮向下滑动,实现图片一张一张加载出来

 3、通过一段代码来实现

<!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>
  <style>
    .viewport {
      width: 250px;
      height: 200px;
      border: 1px solid blue;
      overflow: auto;
    }


    .box1 {
      height: 600px;
      width: 100%;
    }


    .observed {
      width: 100px;
      height: 100px;
      border: 1px solid green;
    }

    .imgs {
      width: 100px;
      height: 100px;
    }
  </style>
</head>
<body>
  <div class="viewport" id="viewport">
    <div class="box1">
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
      <img src="./place.jpg" data-src="https://img.yzcdn.cn/vant/cat.jpeg" alt="图片" class="imgs" />
    </div>
  </div>
  <script>
    let viewport = document.getElementById("viewport"); // 可视区域
    let imgList = document.querySelectorAll(".imgs"); // 被观察元素

    let fn = (e)=>{
      // console.log(e,2222);
      e.forEach(item=>{
      // console.log(item.isIntersecting,666);
      // item.isIntersecting可以看出在视口范围里为true,不在为false    
        if(item.isIntersecting){
          // item.target.src  获取图片src  
          // getAttribute('data-src') 获取自定义属性data-src
          // 在视口里面就赋值
          item.target.src = item.target.getAttribute('data-src')

        }          
      })
    }
    // 开启监听
    let IO = new IntersectionObserver(fn,{}) 
    console.log(IO);
    // 遍历拿到每张图片并监听视口中的图片
    imgList.forEach(item=>{
      IO.observe(item)
    })
  </script>

  
</body>
</html>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值