文章目录
- ⭐前言
- ⭐react 实现滚动加载
- ⭐vue3 实现滚动加载
- ⭐总结
- ⭐结束
⭐前言
大家好,我是yma16,本文分享 前端react&vue3——实现滚动加载(到底部加载)scrollTop 属性
一个双精度浮点值,表示元素当前从原点垂直滚动的像素数,其中正值表示元素向下滚动(以显示更多底部的内容)。如果元素根本没有向上或向下滚动,则 scrollTop 为 0。如果文档不是活动文档,则返回值为 0。如果文档在亚像素精度设备上呈现,则返回的值也是亚像素精度的,可能包含小数部分。
clientHeight 属性
只读属性 Element.clientHeight 对于没有定义 CSS 或者内联布局盒子的元素为 0;否则,它是元素内部的高度(以像素为单位),包含内边距,但不包括边框、外边距和水平滚动条(如果存在)。
clientHeight 可以通过 CSS height + CSS padding - 水平滚动条高度(如果存在)来计算。
scrollHeight 属性
scrollHeight 只读属性是一个元素内容高度的度量,包括由于溢出导致的视图中不可见内容
⭐react 实现滚动加载
判断滚动到底部:Math.ceil(scrollTop+clientHeight+1)>= scrollHeight
这里+1和向上取整是考虑到scrollTop是浮点数
react demo 案例:
效果:
⭐vue3 实现滚动加载
vue3 demo 实例:
效果:
代码块inscode
⭐总结
底部加载的关键判断条件是:Math.ceil(scrollTop + clientHeight + 1) >= scrollHeight。
在使用react时,需要注意通过dom监听数据的变化。而在使用vue3时,数据具有响应式特性,因此只需在滚动加载时添加数据即可。
⭐结束
本文分享到这结束,如有错误或者不足之处欢迎指出!
👍 点赞,是我创作的动力!
⭐️ 收藏,是我努力的方向!
✏️ 评论,是我进步的财富!
💖 最后,感谢你的阅读!
所有评论(0)