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

图片懒加载的核心是“按需加载”,即当图片进入视口(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。
现代推荐用 IntersectionObserver 监听元素是否进入视口,比频繁监听 scroll 更高效、更精准。
立即学习“Java免费学习笔记(深入)”;
class="lazy" 和 data-src 属性dataset.src 赋给 img.src,再移除 lazy 类防止重复加载示例代码:
const lazyImages = document.querySelectorAll('img.lazy');dataset 的使用细节和注意事项img.dataset.src 等价于 img.getAttribute('data-src'),但更简洁。注意以下几点:
data-src,JS 中访问用 dataset.src(驼峰命名:连字符后字母大写,如 data-src-set → dataset.srcSet)data-src 是有效 URL,相对路径需相对于当前页面,不是相对于 JS 文件width/height 或使用 aspect-ratio 防止布局偏移(CLS)data-srcset + data-sizes,加载时再同步赋值给 srcset 和 sizes
对于不支持 IntersectionObserver 的老浏览器(如 IE),可降级为 scroll + getBoundingClientRect 判断;但更推荐用 官方 polyfill。
增强体验方面:
data-src-placeholder)load 事件,加 CSS transition)rootMargin 扩大观察区域,如 '100px')基本上就这些。用好 data- 属性 + IntersectionObserver,就能写出轻量、可靠、符合现代 Web 性能规范的懒加载逻辑。
以上就是JavaScript中如何实现图片懒加载_data属性使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号