随便打开一个网页,基本上都会看到无缝滚动或者轮播图,比如淘宝还有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代码,希望对大家有所帮助!
本文向大家介绍JS平滑无缝滚动效果的实现代码,包括了JS平滑无缝滚动效果的实现代码的使用技巧和注意事项,需要的朋友参考一下 本文我们实现纯JS方式的滚动广告效果。 先show一下成品: 首先是网页样式: 布局如下: 具体的JS实现: 这里要注意的是: scrollLeft代表页面利用滚动条滚动到右侧时,隐藏在滚动条左侧的页面的宽度。 offsetWidth 是对象的可见宽度,包滚动条等边线,会随窗
本文向大家介绍标准的js无缝滚动效果,包括了标准的js无缝滚动效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js无缝滚动效果实现代码,供大家参考,具体内容如下 这种效果的主要思想是图片内容部分的宽度要远远大于要展示区域的宽度,使其出现滚动条。复制上一组图片的内容使其在效果上实现无缝滚动,具体的请大家参考代码。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持
本文向大家介绍js实现无缝滚动图,包括了js实现无缝滚动图的使用技巧和注意事项,需要的朋友参考一下 效果如下: 代码如下: 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持呐喊教程!
本文向大家介绍基于JS实现无缝滚动思路及代码分享,包括了基于JS实现无缝滚动思路及代码分享的使用技巧和注意事项,需要的朋友参考一下 原理: 1.给ul一个绝对定位使其脱离文档流,left设置为0,把图片塞进ul里,编写一个“移动"函数,函数功能能够使ul的left以一个正速度向右跑动, 2.设置一个定时器,让"移动"函数每30(参数可变)毫秒执行一次 3.因为ul的长度会“跑”完,此时可以使ul的
本文向大家介绍js实现无缝滚动特效,包括了js实现无缝滚动特效的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家介绍了js实现无缝滚动特效需要做到的功能,以及关键性js代码,分享给大家供大家参考,具体内容如下 运行效果图: 结合下学了的知识,做个模拟的综合性扩展练习~~ 大致功能如下: 1、点开html后,图片自动移动展示 2、点击左右方向,可以改变 图片移动的方向(改变left的值,正负
本文向大家介绍js代码实现无缝滚动(文字和图片),包括了js代码实现无缝滚动(文字和图片)的使用技巧和注意事项,需要的朋友参考一下 一款适用于方案和图片的JS无缝滚动代码,可控制向左或向右滚动,代码不算复杂,而且本无缝滚动代码兼容性也挺好,你几乎不需要修改什么代码,就能使用了。测试时候把那些带标号的方块都改成图片吧,这样就更有感觉了。 代码如下: 以上所述就是本文针对js代码实现无缝滚动(文字和图