全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

前言

刷网页的时候,有时会遇到这样一个情景,当某个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&&centerY<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>

效果图

总结

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


# 判断dom元素是否存在  # jq判断包含指定的元素  # javascript  # dom  # JS实现利用闭包判断Dom元素和滚动条的方向示例  # 如何用js判断dom是否有存在某class的值  # javascript判断元素存在和判断元素存在于实时的dom中的方法  # JS公共小方法之判断对象是否为domElement的实例  # JS/jQuery判断DOM节点是否存在的简单方法  # 如何判断出一个js对象是否一个dom对象  # JavaScript判断DOM何时加载完毕的技巧  # 基于javascript原生判断DOM是否加载完毕  # 滚动条  # 的是  # 都是  # 这是  # 明白了  # 就不  # 很简单  # 这样一个  # 要知道  # 就可  # 这篇文章  # 它就  # 这三个  # 贴上  # 有时会  # 长宽  # 如何实现  # 就可以  # 如图所示  # 直入 


相关文章: 如何选择适配移动端的WAP自助建站平台?  招贴海报怎么做,什么是海报招贴?  怀化网站制作公司,怀化新生儿上户网上办理流程?  PHP正则匹配日期和时间(时间戳转换)的实例代码  如何破解联通资金短缺导致的基站建设难题?  广州建站公司哪家好?十大优质服务商推荐  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  如何用VPS主机快速搭建个人网站?  如何在宝塔面板创建新站点?  制作网站怎么制作,*游戏网站怎么搭建?  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  如何用IIS7快速搭建并优化网站站点?  建站主机与服务器功能差异如何区分?  如何在局域网内绑定自建网站域名?  建站之星后台管理如何实现高效配置?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  如何通过万网虚拟主机快速搭建网站?  专业公司网站制作公司,用什么语言做企业网站比较好?  如何快速搭建自助建站会员专属系统?  h5网站制作工具有哪些,h5页面制作工具有哪些?  linux top下的 minerd 木马清除方法  油猴 教程,油猴搜脚本为什么会网页无法显示?  香港服务器WordPress建站指南:SEO优化与高效部署策略  如何通过商城免费建站系统源码自定义网站主题?  长沙企业网站制作哪家好,长沙水业集团官方网站?  建站之星图片链接生成指南:自助建站与智能设计教程  建站之星伪静态规则如何设置?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  已有域名和空间如何搭建网站?  C++中引用和指针有什么区别?(代码说明)  Bpmn 2.0的XML文件怎么画流程图  如何用腾讯建站主机快速创建免费网站?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  如何选择CMS系统实现快速建站与SEO优化?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何在橙子建站上传落地页?操作指南详解  如何在Windows 2008云服务器安全搭建网站?  北京专业网站制作设计师招聘,北京白云观官方网站?  如何通过多用户协作模板快速搭建高效企业网站?  制作公司内部网站有哪些,内网如何建网站?  已有域名和空间,如何快速搭建网站?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  实例解析angularjs的filter过滤器  山东网站制作公司有哪些,山东大源集团官网?  代购小票制作网站有哪些,购物小票的简要说明?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  如何快速建站并高效导出源代码?  如何通过cPanel快速搭建网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。