如何监测节点尺寸变化检测

简介: 近来有需求要做分页,听起来可能有点Low。 所以我要把Low的事情做得有点逼格。

前言



近来有需求要做分页,听起来可能有点Low。 所以我要把Low的事情做得有点逼格。

分页本身没啥,但是数据量起来了,比如十万。 要是不做点处理, 那你的页面估计爽得很,机器也爽得很。 放心,我不会让你这么爽。


大量数据展现方案



比较流行的当然是虚拟滚动(无限滚动)。


  1. 始终展示的是有限的固定节点。
  2. 外层创建滚动层。


一句话,就是反复利用固定节点展现数据。


其中还有两个点


何时需要加载新的分页数据

  1. scrollTop , clientHeight, scrollHeight
  2. IntersectionObserver (chrome 55+)


如何知道容器宽高变化


本文就围绕着这个展开


因为使用的是react框架,使用了 react-window, react-window就是用来展现海量数据的react列表组件。


因为项目需要,还要不通尺寸一行展现不同数量的数据。 肯定有人就说,监听window.resize。


没错,监听resize一定程度,但是window.resize, 并不能让我知道容器本身的尺寸,当 然可以通过getComputedStyle获取。 要是window没有resize的情况呢。    


我就想实时的知道尺寸的变化。


尺寸变化监测方案



监测元素resize这里有几种方案的测试和源码。


Cross-Browser, Event-based, Element Resize Detection


思路:

如果IE,直接注册onresize(这个点赞啊)

否则: 创建 type为text/html的object

设置position为absolute, 高度100%, 宽度100% (这样可以获得父容器的宽高)

设置pointer-events:none,利用点击穿透(让object窗体变成幽灵)

object元素的高度变化后,通知订阅者

resize事件节流


问题:

  1. 创建object
  2. 事件处理函数挂载了元素本身上


javascript-detect-element-resize


创建三个子元素,利用scroll事件来监测变化。


原理:

zhuanlan.zhihu.com/p/24887312The scroll event is fired when the document view or an element has been scrolled. 当文档视图或者元素滚动的时候会触发 scroll 事件。 也就是说元素滚动的时候会触发这个事件,那么什么时候元素会滚动?当元素大于其父级元素,且父级元素允许其滚动的时候,该元素可以进行滚动。 换句话说,元素可以滚动意味着父子元素大小不一致,这是这个方法的核心。 那么我们需要让元素大小发生改变时,使得 scrollLeft 或者 scrollTop 发生改变,从而触发 scroll 事件,进一步得知其大小发生了改变。


visibility: hidden; opacity: 0; position: absolute;让自己变得虚无

addEventListener("scroll", scrollListener, true) 在捕捉阶段拦截事件,使用false无效

div.expand-trigger 变大

div.expand-trigger 变小

animationstart来监听显示,比如style.display = 'none'然后style.display = 'block'


问题:


  1. 额外创建四个元素节点以及一个style节点
  2. 事件都挂载了元素本身身上,


ResizeObserver


原生自带的方案, 兼容性并不高,  resize-observer-polyfill 基于resize和MutationOberver的polyfill实现了ResizeObserver。


const resizeObserver = new ResizeObserver(entries => {
        for (let entry of entries) {
            console.log(entry.target.id, `height:${entry.contentRect.height}  width:${entry.contentRect.width}`);
        }
        });
        resizeObserver.observe(document.querySelector('#my_element'));
        resizeObserver.observe(document.querySelector('#my_element2'));
复制代码

此外



当然,我觉得还


  1. 定时器 + getComputedStyle 也是很低成本的实现。
  2. resize + MutationOberver 也是很简单的方案。

写在最后



不忘初衷,有所得,而不为所累,如果你觉得不错,你的一赞一评就是我前行的最大动力。





相关文章
|
2月前
|
运维 数据可视化 定位技术
破局数据中心运维:AR 智能眼镜巡检如何“大显神通”?
AR智能眼镜巡检技术通过虚实融合,将设备状态、操作指引等信息实时叠加至真实场景,有效解决传统数据中心巡检中效率低、易出错、依赖经验等问题。应用于日常巡检、故障排查与远程协作,显著提升运维效率与可靠性,助力数据中心智能化升级。
破局数据中心运维:AR 智能眼镜巡检如何“大显神通”?
|
缓存 JavaScript
解决node与npm版本不一致,出现npm WARN npm npm does not support Node.js v15.14.0
解决node与npm版本不一致,出现npm WARN npm npm does not support Node.js v15.14.0
解决node与npm版本不一致,出现npm WARN npm npm does not support Node.js v15.14.0
|
9月前
|
人工智能 vr&ar
GeneMAN:上海AI Lab联合北大等高校推出的3D人体模型创建框架
GeneMAN是由上海AI实验室、北京大学、南洋理工大学和上海交通大学联合推出的3D人体模型创建框架。该框架能够从单张图片中生成高保真度的3D人体模型,适用于多种应用场景,如虚拟试衣、游戏和娱乐、增强现实和虚拟现实等。
377 7
GeneMAN:上海AI Lab联合北大等高校推出的3D人体模型创建框架
|
11月前
|
监控 关系型数据库 MySQL
如何升级MySQL数据库?
【10月更文挑战第16天】如何升级MySQL数据库?
|
JavaScript Java 测试技术
基于SpringBoot+Vue的在线图书借阅管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue的在线图书借阅管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
123 1
|
JSON 监控 安全
在Linux中,如何使用Suricata进行实时网络威胁检测?
在Linux中,如何使用Suricata进行实时网络威胁检测?
|
边缘计算 负载均衡 网络协议
Intel HDSLB 高性能四层负载均衡器 — 快速入门和应用场景
在云计算、SDN、NFV 高速发展并普遍落地的今天,随着上云业务的用户数量越来越多、数据中心的规模越来越大,云计算规模成本效应越来越重要。因此,云计算的集约式系统架构逻辑就决定了网络的性能是一个永恒的话题。在云网络的技术体系中,对性能追求不仅是方方面面的,而且是极致严苛的。性能每提升一点,成本就降低一分,收益就提高一些,产品的竞争力就更上一层楼。
228 1
Intel HDSLB 高性能四层负载均衡器 — 快速入门和应用场景
使用System.getProperty获取系统属性
使用System.getProperty获取系统属性
|
存储 JavaScript
Vue3使用Pinia获取全局状态变量
Vue3使用Pinia获取全局状态变量
459 4