业务说明
有很多时候,进行图片懒加载
或长列表元素滚动优化
时,就要判断当前元素是否在视窗内可见
原理
计算出当前元素相对目标元素的位置,比如上下左右分别是多少,就可以知道是不是在某一个视窗内;
具体可以用到Element.getBoundingClientRect()
这个方法,MDN查看详情
data:image/s3,"s3://crabby-images/50b82/50b8229c43295baedb3eb5299b3e21c9aecf6802" alt="示例"
具体实现
自己写了一个简单的DEMO,判断小的元素,是否在大元素盒子之内,两者的比较,都是top、bottom、left、right
的值进行比较;
data:image/s3,"s3://crabby-images/73074/73074f37faab5f5e35b90e7dc5fd4ef094e990be" alt="DEMO示例"
代码部分:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
|
const calc = (curEle = null, targetEle = null) => { const _curEle = document.querySelector(curEle) if(!curEle || !_curEle)return const {top: curTop,bottom:curBottom,left:curLeft,right:curRight} = _curEle.getBoundingClientRect() let _targetEle = targetEle || document.documentElement _targetEle = document.querySelector(_targetEle) const {top: targetTop,bottom:targetBottom,left:targetLeft,right:targetRight} = _targetEle.getBoundingClientRect()
let res = false if (curTop >= targetTop && curBottom <= targetBottom && curLeft >= targetLeft && curRight <= targetRight) { res = true } return res }
|
具体DEMO
github地址