首页 > web前端 > js教程 > 正文

JavaScript中如何实现图片懒加载_data属性使用

幻影之瞳
发布: 2025-12-16 21:56:47
原创
307人浏览过
图片懒加载的核心是按需加载,即图片进入视口时才通过data-src属性由JavaScript赋值给src发起请求,避免初始加载阻塞;现代实现推荐使用IntersectionObserver监听,配合dataset.src读取并设置真实地址,同时注意命名规范、路径有效性及布局稳定性。

javascript中如何实现图片懒加载_data属性使用

图片懒加载的核心是“按需加载”,即当图片进入视口(viewport)时才发起请求,避免页面初始加载大量图片拖慢性能。data- 属性(如 data-src)正是实现这一机制的关键载体——它让图片的真正地址暂不写在 src 中,而是先存于自定义属性里,由 JavaScript 控制何时读取并赋值。

为什么data-src 而不是直接写 src

浏览器在解析 HTML 时,只要遇到 <img src="xxx" alt="JavaScript中如何实现图片懒加载_data属性使用" > 就会立即发起网络请求。如果页面有几十张首屏外的图片,全写死 src,不仅浪费带宽,还会阻塞主线程、拉长 LCP(最大内容绘制)时间。
data-src 可以“骗过”浏览器:HTML 里写成

风景

此时浏览器不会加载图片,直到 JS 主动读取 data-src 并赋给 src

基础懒加载实现(原生 JS + Intersection Observer)

现代推荐用 IntersectionObserver 监听元素是否进入视口,比频繁监听 scroll 更高效、更精准。

立即学习Java免费学习笔记(深入)”;

Moshi Chat
Moshi Chat

法国AI实验室Kyutai推出的端到端实时多模态AI语音模型,具备听、说、看的能力,不仅可以实时收听,还能进行自然对话。

Moshi Chat 165
查看详情 Moshi Chat
  • 给所有待懒加载图片加 class="lazy"data-src 属性
  • 创建观察器,监听这些图片是否出现在视口内
  • 一旦触发,把 dataset.src 赋给 img.src,再移除 lazy 类防止重复加载
  • 可选:加载失败时显示占位图或错误提示

示例代码:

const lazyImages = document.querySelectorAll('img.lazy');
const observer = new IntersectionObserver((entries) => {
  entries.forEach(entry => {
    if (entry.isIntersecting) {
      const img = entry.target;
      img.src = img.dataset.src;
      img.classList.remove('lazy');
      observer.unobserve(img); // 停止观察已加载的图片
    }
  });
});
lazyImages.forEach(img => observer.observe(img));

dataset 的使用细节和注意事项

img.dataset.src 等价于 img.getAttribute('data-src'),但更简洁。注意以下几点:

  • HTML 中写 data-src,JS 中访问用 dataset.src(驼峰命名:连字符后字母大写,如 data-src-setdataset.srcSet
  • 确保 data-src 是有效 URL,相对路径需相对于当前页面,不是相对于 JS 文件
  • 建议同时设置 width/height 或使用 aspect-ratio 防止布局偏移(CLS)
  • 若需响应式图片,可用 data-srcset + data-sizes,加载时再同步赋值给 srcsetsizes

兼容性兜底与增强体验

对于不支持 IntersectionObserver 的老浏览器(如 IE),可降级为 scroll + getBoundingClientRect 判断;但更推荐用 官方 polyfill
增强体验方面:

  • 加载中显示骨架屏或模糊占位图(通过 data-src-placeholder
  • 图片加载完成后再淡入(监听 load 事件,加 CSS transition)
  • 对即将进入视口的图片预加载(设置 rootMargin 扩大观察区域,如 '100px'

基本上就这些。用好 data- 属性 + IntersectionObserver,就能写出轻量、可靠、符合现代 Web 性能规范的懒加载逻辑。

以上就是JavaScript中如何实现图片懒加载_data属性使用的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号