近来有需求要作分页,听起来可能有点Low。 因此我要把Low的事情作得有点逼格。
分页自己没啥,可是数据量起来了,好比十万。 要是不作点处理, 那你的页面估计爽得很,机器也爽得很。 放心,我不会让你这么爽。javascript
比较流行的固然是虚拟滚动(无限滚动)。html
一句话,就是反复利用固定节点展示数据。java
其中还有两个点react
什么时候须要加载新的分页数据git
如何知道容器宽高变化
本文就围绕着这个展开github
由于使用的是react框架,使用了 react-window, react-window就是用来展示海量数据的react列表组件。
由于项目须要,还要不通尺寸一行展示不一样数量的数据。 确定有人就说,监听window.resize。
chrome
监测元素resize这里有几种方案的测试和源码。框架
思路:函数
若是IE,直接注册onresize(这个点赞啊)测试
不然: 建立 type为text/html的object
设置position为absolute, 高度100%, 宽度100% (这样能够得到父容器的宽高)
设置pointer-events:none,利用点击穿透(让object窗体变成幽灵)
object元素的高度变化后,通知订阅者
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'
问题:
原生自带的方案, 兼容性并不高, 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'));
固然,我以为还