js 图片懒加载最好的方法

图片懒加载多种方法

第一种 是循环遍历img属性,判断每一个img离顶部的高度减去屏幕的高度是否大于0,小于0的话就就出现在屏幕上了,我们就更改属性显示图片,这种有弊端,因为是监听滚动条,相等于实时监听,消耗性能,不建议使用

第二种 IntersectionObserver 方式,建议使用这种方式,监听属性是否与可视区域交叉,交叉了就显示,如果已经显示过了,可以设置卸载监听

 <!-- 省略多个div -->
  <div>这是内容</div>
  <img
    data-src="https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fup.enterdesk.com%2Fedpic%2F23%2Ff7%2F09%2F23f709d01c0e46f786b7e3c452f313d5.jpg&refer=http%3A%2F%2Fup.enterdesk.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1652581121&t=9f948907a9bae69fd180f093bc996609">
  <img
    data-src="https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fimg.daimg.com%2Fuploads%2Fallimg%2F150404%2F1-1504041A920.jpg&refer=http%3A%2F%2Fimg.daimg.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1652581121&t=c32bdc07b7e00c7d8e1e549b274a6645">
  <img
    data-src="https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fimg.jj20.com%2Fup%2Fallimg%2F1113%2F021620115230%2F200216115230-9-1200.jpg&refer=http%3A%2F%2Fimg.jj20.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1652581121&t=7118acb93585280c8b0092bb38b82012">
  <div></div>
 <!-- 省略多个div -->
  <script>
    var imgs = document.querySelectorAll('img')  //获取img
    
    const callback = entries => {
      entries.forEach(entry => {
        if (entry.isIntersecting) { //entry.isIntersecting 值为 true 说明交叉了 
          const img = entry.target
          const data_src = img.getAttribute('data-src') //获取自定义属性
          img.setAttribute('src', data_src) // 设置src属性
          console.log('图片显示了');
          observe.unobserve(img)  //已经显示过了,就卸载监听
        }
      })
    }

    const observe = new IntersectionObserver(callback)  //实例化IntersectionObserver

    imgs.forEach(img => {
      observe.observe(img)  //监听 img 是否交叉
    })
  </script>

效果: 我们可以看到多次滚动只打印了三次结果 三张图片
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一头小绵羊

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

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

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

打赏作者

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

抵扣说明:

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

余额充值