首页 > 教程
JQUERY判断一个元素是否在可视区域中
- 2024-03-20
- 1383 ℃
基本概念:
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('元素不在页面可视区域内');
}
})
})相关内容
离职时必须清理的电脑文...
微信让女朋友无法删除拉...
微信公众号推送模板消息
教你查询手机号绑定了哪...
【Galgame】什么?你还不...
微信必须关闭那些不该花...
数据缓存Memcached与Redi...
骚扰电话API接口 开源
-
微信公众号涨粉丝技巧
2024-05-07 1493
-
医患纠纷案例解析与防范要点
2024-06-18 1496
-
c++之按序列反转链表
2025-04-08 1378
-
怎么复制网站(禁止鼠标右键复制)内容
2024-02-06 991
-
H5 端唤醒 win10 消息通知
2025-04-07 901
-
快速申请微软 ChatGPT 版新必应方法
2024-07-14 1692
-
PHP保存下载远程文件或图片到本地
2025-04-07 1079
-
免费高清素材图片免费下载
2021-11-08 650
-
Nginx域名跳转 www跳转和不带www
2024-04-23 1677
-
原生JS简易计算器
2025-04-07 1101
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


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