js实现img图片懒加载

在前端中,可以使用 JavaScript 来实现图片的懒加载。下面是一种常见的实现方式:

  1. 在 HTML 文件中,将需要懒加载的图片的 src 属性替换为一个占位符,例如使用一个透明的空白图片或者是一个包含背景色的 div。
  2. 给这些图片添加一个自定义的属性,例如 data-src,并将真实的图片路径作为该属性的值,例如<img data-src="path/to/real/image.jpg">
  3. 使用 JavaScript 监听滚动事件,并检查图片是否进入了可见区域。
  4. 当图片进入可见区域时,将 data-src 属性的值赋给 src 属性,从而触发图片加载。

下面是一个简单的示例代码:

html 复制代码
<!-- HTML -->
<img data-src="path/to/real/image.jpg" class="lazy-load">
javascript 复制代码
// JavaScript
window.addEventListener('DOMContentLoaded', function() {
  var lazyImages = document.querySelectorAll('.lazy-load');
  
  function lazyLoad() {
    lazyImages.forEach(function(img) {
    	let r = img.getBoundingClientRect().top <= window.innerHeight;
    	let u = img.getBoundingClientRect().bottom >= 0 ;
    	let t = getComputedStyle(img).display !== 'none';
      if ( r && u && t ) {
        img.src = img.getAttribute('data-src');
        img.classList.remove('lazy-load');
      }
    });
  }
  
  window.addEventListener('scroll', lazyLoad);
  window.addEventListener('resize', lazyLoad);
  window.addEventListener('orientationchange', lazyLoad);
});

上述代码首先在页面加载完成后获取所有带有 lazy-load 类名的图片。然后,通过监听滚动、窗口调整大小和屏幕旋转等事件,在合适的时机检查图片是否需要加载。 如果图片已经进入可见区域内,就将 data-src 属性的值赋给 src 属性,并移除 lazy-load 类名,触发图片加载。

当然,这只是一个简单的示例代码,实际开发中可能需要处理更多的细节和边界情况。同时,也可以借助第三方的 JavaScript 库来简化懒加载的实现。

相关推荐
小珑也要变强30 分钟前
队列基础概念
c语言·开发语言·数据结构·物联网
AI原吾3 小时前
掌握Python-uinput:打造你的输入设备控制大师
开发语言·python·apython-uinput
机器视觉知识推荐、就业指导3 小时前
Qt/C++事件过滤器与控件响应重写的使用、场景的不同
开发语言·数据库·c++·qt
毕设木哥3 小时前
25届计算机专业毕设选题推荐-基于python的二手电子设备交易平台【源码+文档+讲解】
开发语言·python·计算机·django·毕业设计·课程设计·毕设
珞瑜·3 小时前
Matlab R2024B软件安装教程
开发语言·matlab
weixin_455446173 小时前
Python学习的主要知识框架
开发语言·python·学习
孤寂大仙v3 小时前
【C++】STL----list常见用法
开发语言·c++·list
她似晚风般温柔7894 小时前
Uniapp + Vue3 + Vite +Uview + Pinia 分商家实现购物车功能(最新附源码保姆级)
开发语言·javascript·uni-app
咩咩大主教4 小时前
C++基于select和epoll的TCP服务器
linux·服务器·c语言·开发语言·c++·tcp/ip·io多路复用
FuLLovers4 小时前
2024-09-13 冯诺依曼体系结构 OS管理 进程
linux·开发语言