首页 > 编程 > JavaScript > 正文

关于网页中的无缝滚动的js代码

2019-11-20 09:44:36
字体:
来源:转载
供稿:网友

随便打开一个网页,基本上都会看到无缝滚动或者轮播图,比如淘宝还有360官网的首页

观察这些轮播图可以发现图片可以来回循环地切换,那么是怎样做到的呢?

做到轮播图或者说无缝滚动主要有两种方式,一种是通过对图片的明暗即透明图的改变来显示或隐藏图片,另一种是通过运动框架,将图片显示在可视区域。这两种方式都会用到同一个东西,那就是定时器。

JavaScript中的定时器有两种,1.setInterval();2.setTimeout();相对应的关闭定时器也有两种方法,clearInterval()和clearTimeout()。两种定时器的区别是前者可以执行多次,而后者只执行一次。

这次只说无缝滚动,下篇介绍轮播图。

实现简单的无缝滚动的代码如下:

/*完整的代码*/<!DOCTYPE html><html lang="en"><head><meta charset="utf-8" /><style>div{position:relative;width:630px;height:220px;border:solid 2px black;overflow:hidden;}ul{position:absolute;top:10px;left:0;}img{width:200px;height:200px;float:left;margin-right:10px;border:2px solid yellow;}li{list-style:none;margin:0;padding:0;}ul{margin:0;padding:0;}</style><script>window.onload=function(){var oUl=document.getElementById("main");var aLi=oUl.getElementsByTagName("img");var oInput=document.getElementsByTagName("input")[0];oUl.innerHTML+=oUl.innerHTML;oUl.style.width=aLi.length*aLi[0].offsetWidth+"px";var timer=null;setInterval(function(){oUl.style.left=oUl.offsetLeft-8+"px";if(oUl.offsetLeft<-oUl.offsetWidth/2){oUl.style.left="0px";}},30);};</script></head><body><div><ul id="main"><li><img src="../img/1.jpg"></li><li><img src="../img/2.jpg"></li><li><img src="../img/3.jpg"></li><li><img src="../img/4.jpg"></li><li><img src="../img/9.jpg"></li></ul></div></div></body></html>

/-----------------------------------------------------------------------------------------------------------------------------------------------------------/

无缝滚动的布局比较简单,下面主要讲解JS部分内容:

首先分别获取到ul和li,再将ul里面的内容复制一份,通过js动态修改ul的宽度(如果要做到上下无缝滚动,则修改其宽度),最后开定时器,代码中是每隔30微秒ul向左移动8个像素,而当ul的可视左边距小于ul总长度的一半时,使其变为0。由于计算机的运行速度非常快,所以几乎感觉不到这一变化。我们看到的只是图片不断地向左移动,无休止的运动。

以上所述是小编给大家介绍的关于网页中的无缝滚动的js代码,希望对大家有所帮助!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表