首页 > 教程
JQUERY判断一个元素是否在可视区域中
- 2024-03-20
- 1459 ℃
基本概念:
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('元素不在页面可视区域内');
}
})
})相关内容
JS正则判断校验姓名、手...
如何删除电脑中超大文件
公网IPV6访问家庭设备,...
心中无码,自然高清
PHP采集插件QueryList
PHP模拟浏览器上传文件(...
骚扰电话API接口 开源
实用的JavaScript一行代码
-
微信语音撤回不留痕迹
2021-08-07 1253
-
使用电脑一定要学会的20个小技巧
2024-02-19 908
-
网页上的视频怎么下载
2021-11-22 687
-
竞品分析过后就是抄吗?
2024-05-29 1312
-
电脑必装软件有哪些?请一定别错过这五款
2025-04-26 1054
-
word文档提取目录
2025-04-08 1392
-
视频会员贵,听歌要收费,导航为什么免费
2024-11-26 1450
-
Langchain 教程-文档检索
2025-05-06 1264
-
知乎热榜API、百度热点API、微博热搜API(开源)- 聚合热榜API开源
2025-04-07 1360
-
公网IPV6访问家庭设备,实现文件共享
2024-12-11 2562
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


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