前言

刷网页的时候,有时会遇到这样一个情景,当某个dom元素滚到可见区域时,它就会展现显示动画,十分有趣。那么这是如何实现的呢?
实现原理
想要实现这个功能,就要知道具体的实现原理。下面直入主题。
我们通过浏览器在浏览一个网页时候是这个样子的,如图所示
页面的长宽,以及各dom的坐标都是静止的,动的是显示窗口坐标而已。所以明白了这个,那么判断一个dom元素是否可见时,就十分简单了。
我们需要知道三个坐标就可知道当前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>
效果图
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
# 判断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小时内与您取得联系。