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


Posted in Javascript onMarch 22, 2013

实现思路:

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>
Javascript 相关文章推荐
JavaScript调用后台的三种方法实例
Oct 17 Javascript
javascript中的if语句使用介绍
Nov 20 Javascript
angularjs学习笔记之三大模块(modal,controller,view)
Sep 26 Javascript
JavaScript jquery及AJAX小结
Jan 24 Javascript
javascript入门之window对象【新手必看】
Nov 22 Javascript
理解AngularJs篇:30分钟快速掌握AngularJs
Dec 23 Javascript
JavaScript中的call和apply的用途以及区别
Jan 11 Javascript
Vue结合原生js实现自定义组件自动生成示例
Jan 21 Javascript
JS实现上传图片的三种方法并实现预览图片功能
Jul 14 Javascript
js实现内置计时器
Dec 16 Javascript
js实现数据导出为EXCEL(支持大量数据导出)
Mar 31 Javascript
linux服务器快速卸载安装node环境(简单上手)
Feb 22 Javascript
jQuery+CSS实现菜单滑动伸展收缩(仿淘宝)
Mar 22 #Javascript
使用JavaScript构建JSON格式字符串实现步骤
Mar 22 #Javascript
鼠标滚轮控制网页横向移动实现思路
Mar 22 #Javascript
JQuery实现用户名无刷新验证的小例子
Mar 22 #Javascript
jquery文字上下滚动的实现方法
Mar 22 #Javascript
JS模块与命名空间的介绍
Mar 22 #Javascript
JS在textarea光标处插入文本的小例子
Mar 22 #Javascript
You might like
PHP正确配置mysql(apache环境)
2011/08/28 PHP
dvwa+xampp搭建显示乱码的问题及解决方案
2015/08/23 PHP
php中照片旋转 (orientation) 问题的正确处理
2017/02/16 PHP
PHP创建对象的六种方式实例总结
2019/06/27 PHP
js 浮动层菜单收藏
2009/01/16 Javascript
在JQuery dialog里的服务器控件 事件失效问题
2010/12/08 Javascript
javascript同页面多次调用弹出层具体实例代码
2013/08/16 Javascript
JS创建自定义表格具体实现
2014/02/11 Javascript
jquery中取消和绑定hover事件的实现代码
2016/06/02 Javascript
jQuery简单验证上传文件大小及类型的方法
2016/06/02 Javascript
浅谈jquery的map()和each()方法
2016/06/12 Javascript
jQuery插件ContextMenu自定义图标
2017/03/15 Javascript
JavaScript之RegExp_动力节点Java学院整理
2017/06/29 Javascript
Vue2.0 实现歌手列表滚动及右侧快速入口功能
2018/08/08 Javascript
layui异步加载table表中某一列数据的例子
2019/09/16 Javascript
html中创建并调用vue组件的几种方法汇总
2020/11/17 Javascript
python实现百度关键词排名查询
2014/03/30 Python
Python中变量交换的例子
2014/08/25 Python
Python命令启动Web服务器实例详解
2017/02/23 Python
Python中的错误和异常处理简单操作示例【try-except用法】
2017/07/25 Python
python difflib模块示例讲解
2017/09/13 Python
详谈python read readline readlines的区别
2017/09/22 Python
python实现跨excel的工作表sheet之间的复制方法
2018/05/03 Python
Python3.5面向对象程序设计之类的继承和多态详解
2019/04/24 Python
Python 用matplotlib画以时间日期为x轴的图像
2019/08/06 Python
python实现按首字母分类查找功能
2019/10/31 Python
tensorflow模型转ncnn的操作方式
2020/05/25 Python
美国Curacao百货连锁店网站:iCuracao.com
2019/07/20 全球购物
平安校园建设方案
2014/05/02 职场文书
骨干教师培训方案
2014/05/06 职场文书
2014年最新学校运动会广播稿
2014/09/17 职场文书
教师自我剖析材料(四风问题)
2014/09/30 职场文书
2015年社区纪检工作总结
2015/04/21 职场文书
2016年离婚协议书范文
2016/03/18 职场文书
如何在pycharm中快捷安装pip命令(如pygame)
2021/05/31 Python
Javascript设计模式之原型模式详细
2021/10/05 Javascript