原生实现img-lazyLoad:图片延迟加载(基于intersection Observer)

栏目: JavaScript · 发布时间: 7年前

内容简介:这个api是用来检测dom元素交集的,常见的应用场景之一就是本文提到的对图片进行懒加载,即:拖动窗口滚动条,到达当前这个图片的时候,再去读取挂在自定义属性(比如:'data-src')上的url地址,之后将该url地址写到到src属性上去进行下载、展示这个图片。因此,我们关注的重点是:该图片是否滚动到了当前窗口的可视区域。通常解决的办法是,监听窗口元素的scroll事件,在事件处理程序中对图片的位置做判断。然而,这么做的一个弊端是,因为js是单线程的,而scroll事件出现的又很密集,每次都去响应scrol

intersection Observer简介

点击查阅MDN关于此api的使用说明

这个api是用来检测dom元素交集的,常见的应用场景之一就是本文提到的对图片进行懒加载,即:拖动窗口滚动条,到达当前这个图片的时候,再去读取挂在自定义属性(比如:'data-src')上的url地址,之后将该url地址写到到src属性上去进行下载、展示这个图片。因此,我们关注的重点是:该图片是否滚动到了当前窗口的可视区域。通常解决的办法是,监听窗口元素的scroll事件,在事件处理程序中对图片的位置做判断。然而,这么做的一个弊端是,因为js是单线程的,而scroll事件出现的又很密集,每次都去响应scroll事件可能会影响用户体验。

intersection Observer的诞生就是为了处理这种类似于上文提到的元素交集检测。它会观察我们的 目标元素 ,当 目标元素 出现在 root元素 的可视区域时便会触发一个(我们事先放进去的)回调函数,于是我们可以在回调函数里面处理业务逻辑。

这里出现了两个小概念,对应于本文实现的图片懒加载功能来说:

  • 目标元素:指的就是那些我们需要懒加载的图片
  • root元素指的就是目标元素的父窗口,比如这里的图片的父元素容器

利用intersection Observer实现懒加载

点此查看该案例的stackblitz

查看该案例:

  1. 在index.html页面内有一个scrollContainer,在里面首先是放了几段文字,之后是5个img元素,并将img的url地址写在了自定义属性'data-src'内。
  2. 在css文件内定义了一些样式,其中,move-in是在我们对图片真正进行加载时才会添加的动画效果。

现在,无论我们怎么拖动滚动条都无法看见图片,因为我们仅仅是把img的url写在了自定义属性中而不是src属性中。接下来,我们需要利用intersection Observer对这些暂时看不见的图片元素进行观察,当确认他们滚动到了窗体的可视区域时,我们在回调函数中对其进行加载。

创建一个observer:

const observer = new IntersectionObserver(callback,option)

option配置root元素和回调函数触发机制,这里我们将scrollContainer这个div设为root。

callback就是当检测到目标元素与root元素交集时会调用的函数,形如:

(entrances, observer)=>{
    // entrances是个数组对象,包含了所有的目标元素,通常我们会遍历它们,并判断每一个单独的个体是否与root元素产生了交集,如果是,那么我们就会执行一些逻辑
}

连接目标元素

刚才我们创建了observer,并且设置了它的root元素,现在需要告诉这个observer,我们需要观察哪些目标元素与此root元素的交集。

通过 observer.observe(target) 进行链接

最终的代码

const imgs = document.querySelectorAll('img') //获取所有待观察的目标元素
var options = {
  root: document.querySelector('.scrollContainer'), 
  rootMargin: '0px',
  threshold: 1.0
}
function lazyLoad(target) {
  const observer = new IntersectionObserver((entrances, observer) => {
    entrances.forEach(entrance => {
      if (entrance.isIntersecting) {
        const img = entrance.target;
        const src = img.getAttribute('data-src');
        img.setAttribute('src', src)
        img.classList.add('move-in')
        observer.disconnect()
      }

    })
  }, options);
  observer.observe(target)
}

imgs.forEach(lazyLoad)

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

电子商务:管理与社交网络视角(原书第7版)

电子商务:管理与社交网络视角(原书第7版)

(美)埃弗雷姆·特班(Efraim Turban)、戴维.金(David King)、李在奎、梁定澎、德博拉·特班(Deborrah Turban) / 时启亮、陈育君、占丽 / 机械工业出版社 / 2014-1-1 / 79.00元

本书对电子学习、电子政务、基于web的供应链、协同商务等专题进行了详细的介绍,全书涵盖丰富的资料以及个案,讨论了Web 2.0环境内的产业结构、竞争变化以及对当今社会的影响。另外,本书在消费者行为、协同商务、网络安全、网络交易及客户管理管理、电子商务策略等内容上都有最新的改编,提供读者最新颖的内容,贴近当代电子商务的现实。 本书适合高等院校电子商务及相关专业的本科生、研究生及MBA学员,也可......一起来看看 《电子商务:管理与社交网络视角(原书第7版)》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具