作家
登录

JS实现淘宝幻灯片效果的实现方法

作者: 来源:www.28hudong.com 2013-03-30 00:13:49 阅读 我要评论

实现思路: 1、for循环给数字按钮加上点击事件。 2.for循环先把按钮的样式清空,再把当前样式设置样式。 3、给每个按钮添加自定义属性index aBtn[i].index=i aBtn[2]=2 第二个按钮和第二张图片想对应,用运动框架把大图的UL每次移动-150px,因为图片高度是150px。如果移动到第n张图片就是-150*n。 4、定义变量now,用来自动播放用的。把当前图片赋值给now now=this.index。 5、定义自动播放函数。now++ 下一张,if判断,到最后一张图片的时候就把now设置为0,就是第一张。 if(now==aBtn.length) 6、定义定时器,每2秒就调用一次自动播放函数。 7、鼠标指向图片时就清除定时器。 8、鼠标离开图片时就开启定时器。 复制代码 代码如下: <script> window.onload=function() { var oDiv=document.getElementById('play'); var aBtn=oDiv.getElementsByTagName('ol')[0].getElementsByTagName('li'); var oUl=oDiv.getElementsByTagName('ul')[0]; var now=0; for(var i=0;i<aBtn.length;i++) { aBtn[i].index=i; aBtn[i].onmouseover=function() { now=this.index; //当前值赋给now tab(); } }; function tab() { for(var i=0;i<aBtn.length;i++) { aBtn[i].className=''; //把所有按钮的样式清空 }; aBtn[now].className='active'; //当前按钮样式设置 startMove(oUl,{top:-150*now}); //用运动框架把UL的TOP设置为当前个数*-150,第三张图片就是2*-150 }; function next() { now++; //切换图片 if(now==aBtn.length) //如果到了最后一张图片 { now=0; // 把图片拉回第一张 } tab(); //把图片拉回第一张后继续运动 }; var timer=setInterval(next,2000); //2秒自动切换图片 oDiv.onmouseover=function() { clearInterval(timer); //清除定时器 }; oDiv.onmouseout=function() { timer=setInterval(next,2000); //开启定时器 }; }; </script> 完整代码:复制代码 代码如下:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>淘宝幻灯片上下滑动效果 —— www.zhinengshe.com —— 智能课堂</title> <link href="css.css" rel="stylesheet" type="text/css" /> <script src="baseCommon.js"></script> <script> window.onload=function() { var oDiv=document.getElementById('play'); var aBtn=oDiv.getElementsByTagName('ol')[0].getElementsByTagName('li'); var oUl=oDiv.getElementsByTagName('ul')[0]; var now=0; for(var i=0;i<aBtn.length;i++) { aBtn[i].index=i; aBtn[i].onmouseover=function() { now=this.index; //当前值赋给now tab(); } }; function tab() { for(var i=0;i<aBtn.length;i++) { aBtn[i].className=''; //把所有按钮的样式清空 }; aBtn[now].className='active'; //当前按钮样式设置 startMove(oUl,{top:-150*now}); //用运动框架把UL的TOP设置为当前个数*-150,第三张图片就是2*-150 }; function next() { now++; //切换图片 if(now==aBtn.length) //如果到了最后一张图片 { now=0; // 把图片拉回第一张 } tab(); //把图片拉回第一张后继续运动 }; var timer=setInterval(next,2000); //2秒自动切换图片 oDiv.onmouseover=function() { clearInterval(timer); //清除定时器 }; oDiv.onmouseout=function() { timer=setInterval(next,2000); //开启定时器 }; }; </script> </head> <body> <div class="play" id="play"> <ol> <li class="active">1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> </ol> <ul> <li><a href="http://www.zhinengshe.com/"><img src="images/1.jpg" alt="广告一" /></a></li> <li><a href="http://www.zhinengshe.com/"><img src="images/2.jpg" alt="广告二" /></a></li> <li><a href="http://www.zhinengshe.com/"><img src="images/3.jpg" alt="广告三" /></a></li> <li><a href="http://www.zhinengshe.com/"><img src="images/4.jpg" alt="广告四" /></a></li> <li><a href="http://www.zhinengshe.com/"><img src="images/5.jpg" alt="广告五" /></a></li> </ul> </div> </body> </html>

  推荐阅读

  一些常用弹出窗口/拖放/异步文件上传等实用代码

久不出技术类文章,我都忘了自己是一程序员啦......今天写一点工作中遇到的东西,大家共同学习,反正也比较浅显了。弹出窗口 我们在工作中,经常会碰到弹出窗口类应用,有时候还需要一点遮盖层: 这类圆角弹>>>详细阅读


本文标题:JS实现淘宝幻灯片效果的实现方法

地址:http://www.17bianji.com/kaifa2/JS/22565.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)