iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >如何判断元素是否在可视区域中IntersectionObserver
  • 249
分享到

如何判断元素是否在可视区域中IntersectionObserver

2023-07-05 11:07:03 249人浏览 薄情痞子
摘要

本文小编为大家详细介绍“如何判断元素是否在可视区域中IntersectionObserver”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何判断元素是否在可视区域中IntersectionObserver”文章能帮助大家解决疑惑,下面跟

本文小编为大家详细介绍“如何判断元素是否在可视区域中IntersectionObserver”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何判断元素是否在可视区域中IntersectionObserver”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

应用场景

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

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

使用

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

当一个 IntersectionObserver 对象被创建时,其被配置为监听根中一段给定比例的可见区域。一旦 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”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: 如何判断元素是否在可视区域中IntersectionObserver

本文链接: https://www.lsjlt.com/news/351203.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何判断元素是否在可视区域中IntersectionObserver
    本文小编为大家详细介绍“如何判断元素是否在可视区域中IntersectionObserver”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何判断元素是否在可视区域中IntersectionObserver”文章能帮助大家解决疑惑,下面跟...
    99+
    2023-07-05
  • 面试判断元素是否在可视区域中IntersectionObserver详解
    目录前言应用场景使用结语前言 我们面试中常见的一个问题,如何判断元素是否在可视区域中(即视口区域)?第一时间想到的肯定就是通过,offsetHeight、clientHeight、...
    99+
    2023-03-09
    IntersectionObserver可视区域 IntersectionObserver元素判断
  • IntersectionObserver判断是否在可视区域详解
    目录前言概念使用注意前言 在日常的开发过程中,有时候会有一些要求判断节点是否进入可视化区域的需求。例如:判断信息是否在可视区域曝光再进行曝光,图片懒加载等。通常我们可以通过scrol...
    99+
    2022-11-13
    IntersectionObserver 判断可视区域 IntersectionObserver 可视区域
  • vue如何判断元素是否在可视区域
    今天小编给大家分享一下vue如何判断元素是否在可视区域的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。三种方法:1、利用off...
    99+
    2023-07-04
  • vue怎么判断元素是否在可视区域
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。可视区域是什么可视区域即我们浏览网页的设备肉眼可见的区域,如下图在日常开发中,我们经常需要判断目标元素是否在视窗之内或者和视窗的距离小于一个值(例如 100 px),从而...
    99+
    2023-05-14
    Vue vue3 vue.js
  • JS判断元素是否在可视区域技巧详解
    目录前言实现方式offsetTop、scrollTop注意getBoundingClientRect前言 在日常开发中,我们经常需要判断目标元素是否在视窗之内或者和视窗的距离小于一...
    99+
    2022-12-20
    JS判断元素可视区域 JS 元素可视区域
  • jQuery如何判断元素是否存在
    这篇文章主要介绍了jQuery如何判断元素是否存在,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。判断元素是否存在<script&nbs...
    99+
    2024-04-02
  • es6如何判断元素是否在数组中
    本篇内容介绍了“es6如何判断元素是否在数组中”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • javascript如何判断元素是否在数组中
    这篇文章将为大家详细讲解有关javascript如何判断元素是否在数组中,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 方法:1、使用inde...
    99+
    2024-04-02
  • js如何对元素可视区域进行判定
    目录前言方案介绍使用 getBoundingClientRect使用 scrollTop 与 offsetTop使用 IntersectionObserver注意事项前言 在前端开发...
    99+
    2023-05-17
    js 元素可视区域判定 js 元素可视区域
  • jquery如何判断form元素是否存在
    这篇文章主要讲解了“jquery如何判断form元素是否存在”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“jquery如何判断form元素是否存在”吧! ...
    99+
    2024-04-02
  • jquery如何判断dom元素是否存在
    这篇文章主要介绍jquery如何判断dom元素是否存在,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! jquery判断dom元素是否存在的方法:1、使用“...
    99+
    2024-04-02
  • 如何用Go判断元素是否在切片中
    目录1.问题2.遍历查询3.map 查询4.性能对比5.转换通用化6.借助开源库 golang-set7.小结参考文献1.问题 如何判断元素是否在切片中,Golang 并没有提供直接...
    99+
    2024-04-02
  • jQuery如何判断一个元素是否存在
    这篇文章主要介绍了jQuery如何判断一个元素是否存在,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。判断一个元素是否存在if ($('#someDiv...
    99+
    2023-06-27
  • jquery如何判断某元素是否有子元素
    本篇内容主要讲解“jquery如何判断某元素是否有子元素”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“jquery如何判断某元素是否有子元素”吧! ...
    99+
    2024-04-02
  • jquery如何判断数组元素是否存在
    在jquery中判断数组元素是否存在的方法:1.新建html项目,引入jquery;2.在项目中定义数组;3.使用$.inArray方法判断元素是否存在;具体步骤如下:首先,在新建一个html项目,在项目中引入jquery;<scri...
    99+
    2024-04-02
  • nodejs判断元素是否存在在json
    Node.js是一个基于Chrome V8引擎的JavaScript运行环境,它使得JavaScript可以用于服务端编程。相比于传统的后端开发,Node.js能够高效地处理大量并发请求,这使得它在现代Web应用程序中得到广泛的应用。在No...
    99+
    2023-05-17
  • php如何判断元素是否在二维数组中
    这篇文章主要讲解了“php如何判断元素是否在二维数组中”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php如何判断元素是否在二维数组中”吧!判断步骤:1、使用foreach语句循环遍历二维数...
    99+
    2023-07-02
  • python中如何判断字典中的元素是否存在
    本文小编为大家详细介绍“python中如何判断字典中的元素是否存在”,内容详细,步骤清晰,细节处理妥当,希望这篇“python中如何判断字典中的元素是否存在”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。判断字典中...
    99+
    2023-07-02
  • jquery如何判断元素是否只读
    这篇文章主要介绍“jquery如何判断元素是否只读”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“jquery如何判断元素是否只读”文章能帮助大家解决问题。 ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作