찾다

 >  Q&A  >  본문

javascript - js使用setInterval实现自动轮播图片功能,速度变得越来越快?

1.问题:当初学使用js实现轮播器功能时,页面加载完,自动播放图片运行正常,当鼠标第一次移入ul标签时,自动播放停止,移出鼠标,自动播放继续,
但是随着运行,轮播图片的变化速度非常快,而且这时点击ul标签已经不起作用了,不知道错在哪里了?下面是实现的js代码:

window.onload = function(){
    //轮播初始化
      var lunbo  = document.getElementById('content');
      var imgs = lunbo.getElementsByTagName('img');     
      var uls = lunbo.getElementsByTagName('ul');
      var lis = lunbo.getElementsByTagName('li');
      //初始状态下,一个圆圈为高亮模式
          lis[0].style.fontSize = '26px';
          lis[0].style.color = '#fff';
         //定义一个全局变量,用来进行自动轮播图片顺序的变化
          var pic_index = 1;
        //自动轮播
       var pic_time =  setInterval(autobofang,3000);

         function autobofang(){
             
             if(pic_index >= lis.length){
                pic_index = 0;
            }

                change1(pic_index);
                pic_index++;
         }
        function change1(index){          
                       //让所有图片都不显示,所有圆圈都为普通样式    

                    for(var j=0;j<imgs.length;j++){
                            imgs[j].style.display = 'none';                                 
                            lis[j].style.fontSize = '24px';
                            lis[j].style.color = '#999';
                         }

                     //让选中的索引的图片显示,对应的圆圈高亮  

                    imgs[index].style.display = 'block';                             
                    lis[index].style.fontSize = '26px';
                    lis[index].style.color = '#fff';    

                  //鼠标移入ul标签,自动播放图片暂停

                    uls[0].addEventListener("mouseenter",pause,false);

                     //鼠标移出ul标签,自动播放图片继续

                    uls[0].addEventListener("mouseleave",go,false);
                  
        }
       
       //自动播放暂停函数

       function pause(event){
               var event=event||window.event;
            var target=event.target||event.srcElement;
            switch(target.id){
                case "pic1":

                    clearInterval(pic_time);                  
                    

                break;
                case "pic2":
                        
                      clearInterval(pic_time);
                  

                break;
                case "pic3":
                     
                     clearInterval(pic_time);
                     

                break;
            }
              
       }
     
        //自动播放图片继续函数

         function go(event){
               var event=event||window.event;
            var target=event.target||event.srcElement;
            var children = target.parentNode.children;        
            switch(target.id){
                case "pic1":
                       
                      pic_index = 1;  
                     
                        setInterval(autobofang,3000);

                break;
                case "pic2":

                   pic_index = 2;
                     
                   setInterval(autobofang,3000);

                break;
                case "pic3":

                    pic_index = 3;
                     
                    setInterval(autobofang,3000);               

                break;
            }
              
       }
       /* 问题:当鼠标第一次移入ul标签时,正确,
          但是随着运行,轮播图片的变化速度非常快,而且这时点击ul标签已经不起作用了
        */

       //手动轮播
      for(var i=0;i<lis.length;i++){          
          lis[i].addEventListener("mouseover",change,false);

      }

      function change(event){  

             var event=event||window.event;
             var target=event.target||event.srcElement; 
             var children = target.parentNode.children;           
               for(var i=0;i<children.length;i++){
                         if(target == children[i]){                       
                             for(var j=0;j<imgs.length;j++){
                                   imgs[j].style.display = 'none';                                 
                                   lis[j].style.fontSize = '24px';
                                lis[j].style.color = '#999';
                              }
                                    imgs[i].style.display = 'block';                             
                                    lis[i].style.fontSize = '26px';
                              lis[i].style.color = '#fff';                 
                          
                     }              
              
                      
              }
           } 
     }
PHP中文网PHP中文网2842일 전1318

모든 응답(1)나는 대답할 것이다

  • 阿神

    阿神2017-04-11 11:13:27

    你就在第一次启动setInterval的时候记录获取了pic_time,后面再启动就不记录了?那后面的定时器怎么还能被正常的停止的?停止不了当然就愈来愈快了。

    회신하다
    0
  • 취소회신하다