自动 点击切换 按钮切换 轮播无缝选项卡 ----原生js

Posted 瞅我干啥?

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自动 点击切换 按钮切换 轮播无缝选项卡 ----原生js相关的知识,希望对你有一定的参考价值。

  1 <!doctype html>
  2 <html>
  3 <head>
  4 <meta charset="utf-8">
  5 <meta name="author" content="智能社 - zhinengshe.com" />
  6 <meta name="copyright" content="智能社 - zhinengshe.com" />
  7 <meta name="description" content="智能社是一家专注于web前端开发技术的公司,目前主要提供javascript培训和HTML5培训两项服务,同时还推出了大量javascript基础知识教程,智能课堂为你带来全新的学习方法和快乐的学习体验。" />
  8 <title>智能社— http://www.zhinengshe.com</title>
  9 <style>
 10 *{ margin:0; padding:0; list-style:none;}
 11 #box{ width:534px; height:300px; position:relative; margin:50px auto; overflow:hidden;}
 12 #box ul{ position:absolute; left:0; top:0;}
 13 #box ul li{ float:left; width:534px; height:300px;}
 14 #box ul li img{ height:300px;}
 15 
 16 #box a{ transition:.2s all ease;}
 17 #box .prev,#box .next{position:absolute;  top:50%; z-index:2; height:80px; line-height:80px; background:rgba(0,0,0,0.6); color:#fff; width:80px; text-align:center; margin-top:-40px; display:none;}
 18 #box .prev{ left:0;}
 19 #box .next{ right:0;}
 20 #box a:hover{ background:rgba(255,0,0,0.4);}
 21 
 22 #box ol{ position:absolute; width:120px; left:50%; margin-left:-60px; bottom:10px;}
 23 #box ol li{ width:20px; height:20px; background:#f60; float:left; margin:2px; text-align:center; text-indent:-9999px; border-radius:50%;}
 24 #box ol li.active{ background:#fff;}
 25 </style>
 26 <script>
 27 window.onload=function(){
 28     var oBox=document.getElementById(box);
 29     var oPrev=oBox.children[0];
 30     var oNext=oBox.children[1];
 31     var oUl=oBox.getElementsByTagName(ul)[0];
 32     var aLi=oUl.children;
 33     var oOl=oBox.getElementsByTagName(ol)[0];
 34     var aBtn=oOl.children;
 35     
 36     //先复制一份
 37     oUl.innerHTML+=oUl.innerHTML;
 38     //算宽度
 39     oUl.style.width=aLi.length*aLi[0].offsetWidth+px;
 40     
 41     var W=oUl.offsetWidth/2;
 42     
 43     //移入显示俩按钮
 44     oBox.onmouseover=function(){
 45         clearInterval(timer);
 46         oPrev.style.display=block;
 47         oNext.style.display=block;    
 48     }
 49     oBox.onmouseout=function(){
 50         timer=setInterval(function(){
 51             iNow--;
 52             tab();
 53         },2000);
 54         oPrev.style.display=none;
 55         oNext.style.display=none;    
 56     }
 57     //覆模循环一一对应。
 58     var iNow=0;
 59     
 60     //选项卡
 61     for(var i=0; i<aBtn.length; i++){
 62         (function(index){
 63             aBtn[i].onclick=function(){
 64                 
 65                 if(index==0 && iNow%aBtn.length==aBtn.length-1){//循环一圈后,index=0;iNow%aBtn.length=最后一张图片的时候。iNow都处于
 66                     //++;
 67                     iNow++;    
 68                 }
 69                 if(index==aBtn.length-1 && iNow%aBtn.length==0){//循环一圈后,index=最后一个下标;iNow%aBtn.length=第一张图片的时候。iNow都处于
 70                     //--;
 71                     iNow--;    
 72                 }
 73                 
 74                 if(iNow>0){
 75                     iNow=Math.floor(iNow/aBtn.length)*aBtn.length+index;//Math.floor(iNow/aBtn.length)*aBtn.length  和newMove 对应起来,只要开始动就得走一屏幕。对应的按钮也在对应着变化。
 76                 }else{
 77                     if(index==0 && iNow%aBtn.length==-1){
 78                         iNow++;    
 79                     }
 80                     iNow=Math.floor(iNow/aBtn.length)*aBtn.length+index;    
 81                 }
 82                 tab();
 83                 document.title=iNow;
 84             }
 85         })(i);
 86     }
 87     
 88     function tab(){
 89         for(var i=0; i<aBtn.length; i++){
 90             aBtn[i].className=‘‘;
 91         }
 92         if(iNow<0){
 93             aBtn[(iNow%aBtn.length+aBtn.length)%aBtn.length].className=active;
 94         }else{
 95             aBtn[iNow%aBtn.length].className=active;    
 96         }
 97         //oUl.style.left=-iNow*aLi[0].offsetWidth+‘px‘;    
 98         console.log(iNow)
 99         startMove(oUl,-iNow*aLi[0].offsetWidth);
100     }
101     
102     //点击
103     oNext.onclick=function(){
104         iNow++;
105         tab();
106                 
107     }    
108     var timer=null;
109     timer=setInterval(function(){
110         iNow--;
111         tab();
112     },2000);
113     
114     oPrev.onclick=function(){
115         iNow--;
116         tab();
117         
118     }
119     var left=0;
120     function startMove(obj,iTarget){
121         clearInterval(obj.timer);
122         obj.timer=setInterval(function(){
123             var iSpeed=(iTarget-left)/8;//  总的距离/8得到速度。
124                 //判断speed 正负,来取舍不同的值,不能为小数,每次都要求走一个li宽度。
125             iSpeed=iSpeed>0?Math.ceil(iSpeed):Math.floor(iSpeed);
126             
127             if(left==iTarget){//判断l=iTaegrt要关闭定时器
128                 clearInterval(obj.timer);
129             }else{
130                 left+=iSpeed;
131                 if(left<0){
132                     obj.style.left=left%W+px;
133                 }else{
134                     obj.style.left=(left%W-W)%W+px;    
135                 }
136             }
137             
138         },30);
139     }
140 }
141 </script>
142 </head>
143 
144 <body>
145 <div id="box">
146     <a href="javascript:;" class="prev">prev</a>
147     <a href="javascript:;" class="next">next</a>
148     <ul>
149         <li><img src="img/0.jpg"></li>
150         <li><img src="img/1.jpg"></li>
151         <li><img src="img/2.jpg"></li>
152         <li><img src="img/3.jpg"></li>
153         <li><img src="img/4.jpg"></li>
154     </ul>
155     <ol>
156         <li class="active">0</li>
157         <li>1</li>
158         <li>2</li>
159         <li>3</li>
160         <li>4</li>
161     </ol>
162 </div>
163 </body>
164 </html>

 

以上是关于自动 点击切换 按钮切换 轮播无缝选项卡 ----原生js的主要内容,如果未能解决你的问题,请参考以下文章

javascript如何实现浏览器选项卡的切换?

如何使LayUI的Tab选项卡标签在切换时,自动刷新

[数据可视化大屏教程] 选项卡-轮播切换联动更新图表数据

jquery点击图标来回切换的几种方法(如开关

jquery 广告轮播图

js自动切换选项卡如何实现鼠标移动到相应的内容div中,停止计时。移出后继续自动切换?