0

0

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

幻影之瞳

幻影之瞳

发布时间:2025-12-16 21:56:47

|

307人浏览过

|

来源于php中文网

原创

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

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

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

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

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

风景

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

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

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

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

文希AI写作
文希AI写作

AI论文写作平台

下载
  • 给所有待懒加载图片加 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 性能规范的懒加载逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

788

2023.08.22

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

117

2025.12.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

532

2023.09.20

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

490

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

17

2025.12.06

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

568

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

568

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

516

2023.06.20

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

89

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

CSS教程
CSS教程

共754课时 | 26.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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