玖叶教程网

前端编程开发入门

总是听说图片懒加载,那你能讲清楚吗?(一)

引言

图片懒加载是一种优化网页性能的技术,它可以在网页加载时只加载当前屏幕可视区域内的图片,而不会一次性加载所有图片,从而提高网页的加载速度、减少后台服务器压力,并提升用户体验。让我来详细介绍一下图片懒加载的原理及实现方法。

一、原理

实现图片懒加载的原理可以简单概括为以下几个步骤:

1. 将图片地址存储到 data-xxx 属性上

在 HTML 的 img 标签中,我们可以使用自定义的 data-xxx 属性来存储图片地址,例如:

<img src="placeholder.jpg" data-src="image.jpg">

这样,我们就可以在图片加载时通过 JavaScript 获取到图片地址。

2. 判断图片是否在可视区域

通过计算每张图片的位置,我们可以判断当前图片是否在可视区域内。一般来说,我们可以通过以下两个方法来计算图片的位置:

(1) getBoundingClientRect() 方法

这个方法可以获取元素的大小、位置等信息,包括元素相对于视口的位置。通过计算元素的 top、bottom、left、right 等属性可以得出元素的位置信息,例如:

const rect = element.getBoundingClientRect();
const top = rect.top;
const bottom = rect.bottom;
const left = rect.left;
const right = rect.right;

(2) offsetTop 和 offsetHeight 属性

这两个属性可以获取元素相对于其父元素的位置和大小。通过计算元素的 offsetTop 和 offsetHeight 属性可以得出元素的位置信息,例如:

const top = element.offsetTop;
const height = element.offsetHeight;
const bottom = top + height;

3. 如果在,就设置图片 src

当图片在可视区域内时,我们就可以将 data-src 属性的值赋给 img 标签的 src 属性,从而开始加载图片。例如:

if (isInViewport(image)) {
image.src = image.dataset.src;
}

4. 绑定 scroll 监听事件

为了实现图片懒加载,我们需要监听页面的滚动事件,当滚动时判断图片是否在可视区域内,如果在就加载图片。例如:

window.addEventListener('scroll', function() {
images.forEach(function(image) {
if (isInViewport(image)) {
image.src = image.dataset.src;
}
});
});

二、实现方法

基于上述原理,我们就可以实现图片懒加载的功能。下面是一个简单的实现方法:

<img src="placeholder.jpg" data-src="image.jpg">
<img src="placeholder.jpg" data-src="image2.jpg">
<img src="placeholder.jpg" data-src="image3.jpg">

<script>
const images = document.querySelectorAll('img[data-src]');

function isInViewport(element) {
const rect = element.getBoundingClientRect();
return rect.bottom > 0 &&
rect.right > 0 &&
rect.left < (window.innerWidth || document.documentElement.clientWidth) &&
rect.top < (window.innerHeight || document.documentElement.clientHeight);
}

function lazyLoad() {
images.forEach(function(image) {
if (isInViewport(image)) {
image.src = image.dataset.src;
image.removeAttribute('data-src');
}
});
}

window.addEventListener('scroll', lazyLoad);
window.addEventListener('resize', lazyLoad);
window.addEventListener('orientationchange', lazyLoad);

lazyLoad();
</script>

在上面的代码中,我们首先通过 querySelectorAll() 方法获取所有带有 data-src 属性的 img 标签,然后定义了一个 isInViewport() 函数,用于判断元素是否在可视区域内。在 lazyLoad() 函数中,我们遍历所有带有 data-src 属性的 img 标签,如果它们在可视区域内,就将 data-src属性的值赋给src属性,并将data-src 属性删除,从而开始加载图片。最后,我们将 lazyLoad() 函数绑定到 window 对象的scroll、resize和orientationchange事件上,以便在窗口大小或方向变化时重新计算图片位置。

三、总结

图片懒加载是一种优化网页性能的技术,它可以在网页加载时只加载当前屏幕可视区域内的图片,从而提高网页的加载速度、减少后台服务器压力,并提升用户体验。

实现图片懒加载的原理可以简单概括为以下几个步骤:将图片地址存储,判断图片是否在可视区域,如果在就绑定监听事件。我们可以通过计算图片的位置来判断它是否在可视区域内,在实现图片懒加载时,我们可以遍历并判断是否在可视区域内,然后开始加载图片,最后计算图片位置。

还有一些优化可以进一步提高图片懒加载的效率和性能,我们在下一篇文章中再来向大家介绍它们。

那么这篇文章就到这里结束啦~

如果你想了解更多这类文章,点赞关注作者更新更多~


作者:Yiko
链接:https://juejin.cn/post/7300036605100130358

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言