面试判断元素是否在可视区域中IntersectionObserver详解

 更新时间:2023年03月09日 11:16:17   作者:收破烂的来了  
这篇文章主要为大家介绍了判断元素是否在可视区域中IntersectionObserver面试详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

前言

我们面试中常见的一个问题,如何判断元素是否在可视区域中(即视口区域)?第一时间想到的肯定就是通过,offsetHeight、clientHeight、scrollHeight、scrrollTop、window.innerHeight等等东西来计算。而IntersectionObserver更好的帮我们解决了这个问题。

应用场景

去实现懒加载、无限滚动等等操作。

例:使用到的场景就是大量数据展示问题,一次性渲染大量数据,肯定会出现渲染性能问题。如:一个select选择框,有大量数据,而视口展示的内容只有其中一小小部分。我们只需要先渲染视口展示的内容,当用户滚动的时候,再渲染剩下的数据。这也是为什么在面试中要问这个问题。

使用

先放链接IntersectionObserver - Web API 接口参考 | MDN (mozilla.org)

IntersectionObserver 接口(从属于 Intersection Observer API)提供了一种异步观察目标元素与其祖先元素或顶级文档视口(viewport)交叉状态的方法。其祖先元素或视口被称为根(root)

当一个 IntersectionObserver 对象被创建时,其被配置为监听根中一段给定比例的可见区域。一旦 IntersectionObserver 被创建,则无法更改其配置,所以一个给定的观察者对象只能用来监听可见区域的特定变化值;然而,你可以在同一个观察者对象中配置监听多个目标元素。

现在就用一个例子演示

 <ul>
      <li ref="li" v-for="(item, index) in lis" :key="index">{{ item }}</li>
    </ul>
const lis = reactive([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])

我这里创建了一个ul 里面有很多小(10个)li。然后我们想实现懒加载就需要用到IntersectionObserver这个API

第一步:先要获取需要监听元素的DOM,那我们这里需要获取滚动条数据的最后一个元素,也就是:li.value[li.value.length - 1](即li的最后一个DOM元素)。

   const li = ref(null)

然后我们创建IntersectionObserver实例对象。 语法

var observer = new IntersectionObserver(callback[, options]); 这里有几个参数解释:

callback

当元素可见比例超过指定阈值后,会调用一个回调函数,此回调函数接受两个参数:

entries

一个IntersectionObserverEntry对象的数组,每个被触发的阈值,都或多或少与指定阈值有偏差。

observer

被调用的IntersectionObserver实例。

  const intersectionObserver = new IntersectionObserver((entries) => {
  // 如果 intersectionRatio 为 0,则目标在可视区域之外,
  //直接return
  if (entries[0].intersectionRatio <= 0) return
  //停止在前一个DOM的监听。
  intersectionObserver.disconnect(li.value[li.value.length - 1])
  //如过在可视区域之内,则我们添加数据。
  lis.push(...[1, 2, 3, 4, 5, 6])
  //更新监听的DOM
  intersectionObserver.observe(li.value[li.value.length - 1])
  console.log('Loaded new items')
})
onMounted(() => {
  //这里对li的最后一个组件进行监听。
  intersectionObserver.observe(li.value[li.value.length - 1])
})

这样就能够实现一个懒加载的效果。

由此可见IntersectionObserver是多么的方便,而且还节省性能。

结语

IntersectionObserver现在对绝大多数浏览器都兼容,对于极个别可能不支持,在我们日常开发中也可以提供很大帮助。

虽然现在的组件库多种多样,且许多地方都已经自带了懒加载的操作方法,无需了解其原理。但如果想要我们的技术更上一个台阶需要更加去了解。

参考资料 IntersectionObserver - Web API 接口参考 | MDN (mozilla.org)

以上就是面试判断元素是否在可视区域中IntersectionObserver详解的详细内容,更多关于IntersectionObserver可视区域的资料请关注脚本之家其它相关文章!

相关文章

  • redux-saga 初识和使用

    redux-saga 初识和使用

    这篇文章主要介绍了redux-saga 初识和使,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Three.js基础学习之场景对象

    Three.js基础学习之场景对象

    这篇文章主要给大家介绍了Three.js基础学习之场景对象的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用three.js具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。
    2017-09-09
  • 弹出遮罩层后禁止滚动效果【实现代码】

    弹出遮罩层后禁止滚动效果【实现代码】

    下面小编就为大家带来一篇弹出遮罩层后禁止滚动效果【实现代码】。小编觉得挺不错的,现在分享给大家,也给大家做个参考
    2016-04-04
  • 基于JS实现EOS隐藏错误提示层代码

    基于JS实现EOS隐藏错误提示层代码

    本文给大家分享一段代码基于js实现EOS隐藏错误提示层,对eos隐藏提示层的相关知识感兴趣的朋友一起学习吧
    2016-04-04
  • 基于javascript实现按圆形排列DIV元素(二)

    基于javascript实现按圆形排列DIV元素(二)

    本篇文章主要介绍基于javascript实现按圆形排列DIV元素的方法,此文着重于介绍怎样实现的按圆形排列DIV元素的运动原理和实现效果代码,需要的朋友来看下吧
    2016-12-12
  • javaScript实现网页版的弹球游戏

    javaScript实现网页版的弹球游戏

    这篇文章主要为大家详细介绍了javaScript实现网页版的弹球游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • Sample script that displays all of the users in a given SQL Server DB

    Sample script that displays all of the users in a given SQL

    Sample script that displays all of the users in a given SQL Server DB...
    2007-06-06
  • 使用JavaScript实现LRU缓存的代码详解

    使用JavaScript实现LRU缓存的代码详解

    LRU(Least Recently Used)算法是一种广泛应用于内存管理和缓存系统的策略,本文将介绍LRU算法的基本原理,并通过JavaScript实现案例,帮助读者理解其在前端开发中的应用场景,需要的朋友可以参考下
    2024-05-05
  • javascript获取文档坐标和视口坐标

    javascript获取文档坐标和视口坐标

    制作网页的过程中,你有时候需要知道某个元素在网页上的确切位置。下面的教程总结了Javascript在网页定位方面的相关知识。有需要的小伙伴可以参考下。
    2015-05-05
  • javascript中不提供sleep功能如何实现这个功能

    javascript中不提供sleep功能如何实现这个功能

    javascript中不提供sleep功能,而我们时长会用到这个功能,下面与大家分享个不错的解决方法,而且在不同的机器上的执行速度是一致的
    2014-05-05

最新评论