JS判断指定dom元素是否在屏幕内的方法实例


Posted in Javascript onJanuary 23, 2017

前言

刷网页的时候,有时会遇到这样一个情景,当某个dom元素滚到可见区域时,它就会展现显示动画,十分有趣。那么这是如何实现的呢?

实现原理

想要实现这个功能,就要知道具体的实现原理。下面直入主题。

我们通过浏览器在浏览一个网页时候是这个样子的,如图所示

JS判断指定dom元素是否在屏幕内的方法实例

页面的长宽,以及各dom的坐标都是静止的,动的是显示窗口坐标而已。所以明白了这个,那么判断一个dom元素是否可见时,就十分简单了。

我们需要知道三个坐标就可知道当前dom是否在可见区域内,分别是

  1. 显示窗口的顶部坐标
  2. 显示窗口的底部坐标
  3. dom元素的中心坐标

其判断规则就是,当dom元素的中心坐标的X及Y坐标均小于显示窗口的顶部,且大于显示窗口的底部坐标时,那么就可以判断该坐标在可见区域。

OK,那么接下来就是要知道这三个坐标怎么计算了。

首先是窗口的顶部坐标,顶部坐标就是页面的滚动条滚动的距离。

其次是底部坐标,底部坐标就是滚动条的距离加上当前可视窗口的高度。

最后dom元素的中心距离,就是这个dom元素到最顶端的高度加上自身高度的一般。

原理就是那么的简单有木有。

具体实现

明白了原理,具体实现起来就很简单啦。下面直接贴上一个简单的dom代码做下示例,在实际的生产中还是要优化的,比如初次的首屏显示等等,这里就不赘述了。

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
</head>
<style type="text/css">
 .box {
 width: 100%;
 height: 200px;
 background: #ff0000;
 margin-bottom: 10px;
 text-align: center;
 color: #fff;
 line-height: 200px;
 font-family: microsoft yahei;
 font-size: 40px;
 
 }
 .animate{
 animation: showText 1s;
 }
 @keyframes showText
 {
 from {
 font-size: 20px;
 }
 to {
 font-size: 40px;
 }
 }
</style>
<body>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
</body>
<script type="text/javascript">
 
 var box = document.getElementsByClassName('box');
 document.addEventListener('scroll',function(){
  
  //滚动条高度+视窗高度 = 可见区域底部高度
  var visibleBottom = window.scrollY + document.documentElement.clientHeight;
  //可见区域顶部高度
  var visibleTop = window.scrollY;
  for (var i = 0; i < box.length; i++) {
  var centerY = box[i].offsetTop+(box[i].offsetHeight/2);
  if(centerY>visibleTop&¢erY<visibleBottom){
   box[i].innerHTML = '区域可见'
   box[i].setAttribute("class",'box animate')
   console.log('第'+i+'个区域可见');
  }else{
   box[i].innerHTML = '';
   box[i].setAttribute("class",'box')
   console.log('第'+i+'个区域不可见');
  }
  }
 })
</script>
</html>

效果图

JS判断指定dom元素是否在屏幕内的方法实例

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
jquery简单体验
Jan 10 Javascript
JavaScript1.6数组新特性介绍以及JQuery的几个工具方法
Dec 06 Javascript
JS实现网站菜单拖拽移位效果的方法
Sep 24 Javascript
基于javascript实现右下角浮动广告效果
Jan 08 Javascript
纯css下拉菜单 无需js
Aug 15 Javascript
bootstrap table复杂操作代码
Nov 01 Javascript
浅析Node.js:DNS模块的使用
Nov 23 Javascript
js使用i18n实现页面国际化的方法
May 09 Javascript
微信小程序 swiper组件构建轮播图的实例
Sep 20 Javascript
浅谈vue,angular,react数据双向绑定原理分析
Nov 28 Javascript
JS获取动态添加元素的方法详解
Jul 31 Javascript
jQuery实现轮播图效果demo
Jan 11 jQuery
jQuery弹出层插件popShow用法示例
Jan 23 #Javascript
Javascript中for循环语句的几种写法总结对比
Jan 23 #Javascript
基于jQuery插件jqzoom实现的图片放大镜效果示例
Jan 23 #Javascript
JavaScript在form表单中使用button按钮实现submit提交方法
Jan 23 #Javascript
canvas绘制表盘时钟
Jan 23 #Javascript
canvas绘制的直线动画
Jan 23 #Javascript
node.js实现复制文本到剪切板的功能
Jan 23 #Javascript
You might like
Php部分常见问题总结
2006/10/09 PHP
分页详解 从此分页无忧(PHP+mysql)
2007/11/23 PHP
PHP 手机归属地查询 api
2010/02/08 PHP
PHP采集静态页面并把页面css,img,js保存的方法
2014/12/23 PHP
php解决crontab定时任务不能写入文件问题的方法分析
2019/09/16 PHP
在IE中调用javascript打开Excel的代码(downmoon原作)
2007/04/02 Javascript
JavaScript的Module模式编程深入分析
2013/08/13 Javascript
JavaScript字符串对象slice方法入门实例(用于字符串截取)
2014/10/16 Javascript
jQuery中removeProp()方法用法实例
2015/01/05 Javascript
JavaScript中Cookie操作实例
2015/01/09 Javascript
js实现精美的银灰色竖排折叠菜单
2015/05/16 Javascript
jQuery的remove()方法使用详解
2015/08/11 Javascript
JS+CSS实现简单的二级下拉导航菜单效果
2015/09/21 Javascript
JS实现选中当前菜单后高亮显示的导航条效果
2015/10/15 Javascript
yarn与npm的命令行小结
2016/10/20 Javascript
jQuery实现的点击显示隐藏下拉菜单功能完整示例
2019/05/17 jQuery
小程序组件之自定义顶部导航实例
2019/06/12 Javascript
ES6中异步对象Promise用法详解
2019/07/31 Javascript
解决layui-open关闭自身窗口的问题
2019/09/10 Javascript
vue用BMap百度地图实现即时搜索功能
2019/09/26 Javascript
通过js随机函数Math.random实现乱序
2020/05/19 Javascript
python实现的简单抽奖系统实例
2015/05/22 Python
python Spyder界面无法打开的解决方法
2018/04/27 Python
浅谈python中get pass用法
2019/03/19 Python
Python多版本开发环境管理工具介绍
2019/07/03 Python
Python的matplotlib绘图如何修改背景颜色的实现
2019/07/16 Python
Python 动态变量名定义与调用方法
2020/02/09 Python
Python运行异常管理解决方案
2020/03/09 Python
DataFrame 数据合并实现(merge,join,concat)
2020/06/14 Python
CSS3 实用技巧:实现黑白图像效果示例代码
2013/07/11 HTML / CSS
html5组织内容_动力节点Java学院整理
2017/07/10 HTML / CSS
学校对教师的评语
2014/04/28 职场文书
高速铁道技术专业求职信
2014/08/09 职场文书
党委书记个人检查对照材料思想汇报
2014/10/11 职场文书
钱塘江大潮导游词
2015/02/03 职场文书
《狼王梦》读后感:可怜天下父母心
2019/11/01 职场文书