监测元素resize
前言
近来有需求要做分页,听起来可能有点Low。 所以我要把Low的事情做得有点逼格。
分页本身没啥,但是数据量起来了,比如十万。 要是不做点处理, 那你的页面估计爽得很,机器也爽得很。 放心,我不会让你这么爽。
大量数据展现方案
比较流行的当然是虚拟滚动(无限滚动)。
- 始终展示的是有限的固定节点。
- 外层创建滚动层。
一句话,就是反复利用固定节点展现数据。
其中还有两个点
何时需要加载新的分页数据
- scrollTop , clientHeight, scrollHeight
- 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事件节流
问题:
- 创建object
- 事件处理函数挂载了元素本身上
javascript-detect-element-resize
创建三个子元素,利用scroll事件来监测变化。
原理:
https://zhuanlan.zhihu.com/p/24887312
The 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'
问题:
- 额外创建四个元素节点以及一个style节点
- 事件都挂载了元素本身身上,
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'));
此外
当然,我觉得还
- 定时器 + getComputedStyle 也是很低成本的实现。
- resize + MutationOberver 也是很简单的方案。
监测元素resize的更多相关文章
- ResizeObserver - 元素resize监听API
Motivation 响应式网站/Web应用程序 根据视口大小调整内容展示方式.这通常通过CSS和media查询来完成.当CSS表现不好我们会使用Javascript. 比如document.addE ...
- ResizeObserver - 元素resize监听API ResizeObserver
Motivation 响应式网站/Web应用程序 根据视口大小调整内容展示方式.这通常通过CSS和media查询来完成.当CSS表现不好我们会使用Javascript. 比如document.addE ...
- HTML元素事件说明
blur( ) 元素失去焦点 a, input, textarea, button, select, label, map, area change( ) 用户改变域的内容 input, textar ...
- jQuery 绑定事件及移除绑定事件方法和元素事件列表
1.jQuery Event 事件: ready(fn); $(document).ready()注意在body中没有onload事件,否则该函数不能执行.在每个页面中可以有很多个函数被加载 ...
- STL标准模板库(简介)
标准模板库(STL,Standard Template Library)是C++标准库的重要组成部分,包含了诸多在计算机科学领域里所常见的基本数据结构和基本算法,为广大C++程序员提供了一个可扩展的应 ...
- Mac 开发者常用的工具
转载:http://www.oschina.net/news/53946/mac-dev-tools 在写 Mac 程序员的十个武器之前,我决定先讲一个故事,关于 Mac 和爱情的.(你们不是问 Ma ...
- 为什么DOM操作很慢
转自:http://kb.cnblogs.com/page/534571/ 一直都听说DOM很慢,要尽量少的去操作DOM,于是就想进一步去探究下为什么大家都会这样说,在网上学习了一些资料,这边整理出来 ...
- JQuery常用方法一览
$(”p”).addClass(css中定义的样式类型); 给某个元素添加样式 $(”img”).attr({src:”test.jpg”,alt:”test Image”}); 给某个元素添加属性/ ...
- vector的主要操作
vector常用方法 assign() 对Vector中的元素赋值 void assign( input_iterator start, input_iterator end ); // void a ...
随机推荐
- gcc -frandom-seed
-frandom-seed=string This option provides a seed that GCC uses when it would otherwise use random nu ...
- (转)apache2.2.x+tomcat7.0.x集群+…
apache http server下载地址 http://httpd.apache.org/download.cgi#apache22 这里下载的是httpd-2.2.21-win32-x86-op ...
- go开发环境搭建及开发工具简介
go语言包的下载地址:https://www.golangtc.com/download 这里以window10的操作系统环境为例 go的开发工具下载地址:https://www.golangtc.c ...
- HDU - 6025 Coprime Sequence(gcd+前缀后缀)
Do you know what is called ``Coprime Sequence''? That is a sequence consists of nnpositive integers, ...
- C#——传值参数(3)
上篇文章我与大家共同学习了 值参数——引用类型这次与大家共同学习 传值参数--引用类型,不创建新对象,只操作对象这是个思维导图:我们仍需记住:1.值参数创建变量的副本 2.对值参数的改变不会影响变量的 ...
- 【Unity】物理碰撞实验
http://www.cnblogs.com/javawebsoa/archive/2013/05/18/3085818.html 这几天为了准备面试,所以决定对平时学习中的盲点扫盲一下,首先想到的就 ...
- JS 识别生日、性别、年龄
<script> function IdCard(UUserCard,num){ if(num==1){ //获取出生日期 birth=UUserCard.substring(6, 10) ...
- poj 2769 感觉♂良好 (单调栈)
poj 2769 感觉♂良好 (单调栈) 比尔正在研发一种关于人类情感的新数学理论.他最近致力于研究一个日子的好坏,如何影响人们对某个时期的回忆. 比尔为人的一天赋予了一个正整数值. 比尔称这个值为当 ...
- jQuery EasyUI/TopJUI创建日期输入框
jQuery EasyUI/TopJUI创建日期输入框 日期时间输入框组件 HTML required:必填字段,默认为false:prompt:显示在输入框的提示性文字:pattern:日期格式 Y ...
- UML工具 PlantUML SequenceDiagram