首页 > 教程
JQUERY判断一个元素是否在可视区域中
- 2024-03-20
- 1414 ℃
基本概念:
offsetTop指元素的上外边框至包含元素的上内边框之间的像素距离,其他方向相同
offsetWidth指元素两端算上外边框的宽度,其他方向相同
scrollLeft 和 scrollTop既可以确定当前元素的滚动状态,也可以设置元素的滚动位置
scrollWidth 和 scrollHeight确定元素内容的实际大小
clientWidth元素内容区宽度加上左右内边距宽度,即clientWidth = content + padding
clientHeight元素内容区高度加上上下内边距高度,即clientHeight = content + padding

在日常开发中,我们经常需要判断目标元素是否在可视窗口内,从而实现一些常用的功能,如果一个元素在视窗内,那么它一定满足下面四个条件:
top <= 0;
left <= 0;
bottom <= 视窗高度;
right <= 视窗高度。

isInViePortOfTwo判断元素是否在可视区域内:
function isInViePortOfTwo(el){
const viewPortHeight = window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight
const viewPortWidth = window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth
const {top,right,bottom,left} = el.getBoundingClientRect();
return top>=0 && left>=0 && bottom<=viewPortHeight && right<=viewPortWidth
}页面滚动时添加监听事件:
$(window).on("scroll",()=>{
$targets.each((index,element)=>{
if(isInViewPort(element)){
console.log('元素在页面可视区域内');
}else{
console.log('元素不在页面可视区域内');
}
})
})相关内容
让你的DeepSeek能力翻倍...
瞬间无损截取合并视频的...
微信必须关闭那些不该花...
splice变相跳出forEach循环
2025年8款免费且好用的图...
Android Studio打包APK...
微信免费听歌,畅享 QQ 音乐
PHP判断URL的合法性字符...
-
Vue3项目Build后部署在Nginx上F5刷新页面空白或404
2025-04-07 1100
-
PHP判断URL的合法性字符串是否为 URL 链接
2025-04-07 895
-
什么是暗网,暗网不是冒险乐园,它是网络世界的禁区
2025-10-24 945
-
医患纠纷案例解析与防范要点
2024-06-18 1536
-
为什么您的电脑有弹窗广告,垃圾广告
2025-03-10 1212
-
splice变相跳出forEach循环
2025-04-07 1075
-
如何去除上网冲浪的广告
2025-03-10 1406
-
微信语音撤回不留痕迹
2021-08-07 1214
-
通过 SWOT 分析法,看美团优选的先天优势
2024-05-29 2776
-
微信提现免手续费
2024-11-18 1331
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


进入有缘空间
点击分享文章