zoukankan      html  css  js  c++  java
  • jQuery左右图文滚动

    这个是图文的左右滚动,一般是一版几个图片,图片下面配有文字。

    现在实现的有:文档首次载入后,会自动切换。如果点击了左右按钮或者是下面的索引小圆,就会关闭定时器。

    需要解决的问题是,如果不对轮播图进行操作后3s,它又会自动开启定时器进行切换了。

    jQuery实现的要添加一个jQuery库文件。可以是本地的,也可是在线的。

    好了,话不多说,上代码哈。

    html:

     1 <div class="container">
     2 <span id="prev" class="prev btn">&lt;</span>
     3 <span id="next" class="next btn">&gt;</span>
     4 <div class="img_container">
     5  <div class="imgbox" style="left:0">
     6   <ul>
     7    <li style="background:red;">1</li>
     8    <li style="background:blue;">2</li>
     9    <li style="background:pink;">3</li>
    10    <li>4</li>
    11    <li style="background:#ccc;">5</li>
    12    <li style="background:010101;">6</li>
    13    <li style="background:green;">7</li>
    14    <li style="background:maroon;">8</li>
    15    <li style="background:#6A3939;">9</li>
    16    <li style="background:#0D5224;">10</li>
    17    <li style="background:#0D156F;">11</li>
    18    <li style="background:#861271;">12</li>
    19    <li style="background:#3E0858;">13</li>
    20    <li style="background:#C42C64;">14</li>
    21    <li style="background:#403E05;">15</li>
    22   </ul>
    23  </div>
    24  <div class="circle">
    25   <span class="current">1</span><span>2</span><span>3</span><span>4</span>
    26  </div>
    27 </div>
    28 </div>

    css:

     1 <style>
     2 *{
     3   margin:0;
     4   padding:0;
     5 }
     6 .container{
     7   width:700px;
     8   height:300px;
     9   border:1px solid #000;
    10   margin:50px auto;    
    11   position:relative;
    12 }
    13 .container span.btn{
    14   display:block;
    15   width:30px;
    16   height:100px;
    17   line-height:100px;
    18   text-align:center;
    19   font-size:40px;
    20   background:rgba(0,0,0,.3);
    21   position:absolute;
    22   top:100px;
    23   cursor:pointer;
    24   display:none;    
    25 }
    26 .container:hover span.btn{
    27   display:block;    
    28 }
    29 .container span.btn:hover{
    30   background:rgba(0,0,0,.6);
    31 }
    32 .container span.btn.prev{
    33   left:0;    
    34 }
    35 .container span.btn.next{
    36   right:0;    
    37 }
    38 /**/
    39 .img_container{
    40   width:600px;
    41   height:240px;
    42   border:1px solid red;
    43   margin:30px auto;    
    44   overflow:hidden;
    45   position:relative;
    46 }
    47 .img_container .imgbox{
    48   position:absolute;
    49   left:0;
    50   top:0;
    51   width:2400px;    
    52 }
    53 .img_container .imgbox li{
    54   float:left;
    55   list-style:none;
    56   width:130px;
    57   height:200px;
    58   background:#f60;
    59   margin:10px;    
    60   font-size:30px;
    61   color:white;
    62   line-height:200px;
    63   text-align:center;
    64   margin-top:20px;
    65 }
    66 
    67 /*焦点图下面的显示索引的小圆环*/
    68 .img_container .circle{
    69   width:64px;
    70   height:12px;
    71   position:absolute;
    72   bottom:4px;
    73   left:268px;    
    74 }
    75 .img_container .circle span{
    76   display:block;
    77   float:left;
    78   width:10px;    
    79   height:10px;
    80   background:#9DA5A5;
    81   font-size:12px;
    82   margin-right:4px;
    83   text-indent:-9999px;
    84   border-radius:50%;
    85   border:1px solid #000;
    86   cursor:pointer;
    87 }
    88 .img_container .circle span.current{
    89   background:#FF4500;    
    90 }
    91 </style>

    js:

      1 <script>
      2 $(function(){
      3   var page = 1;  //定义为当前第一页
      4   var i = 4;  //每版放四个图片
      5   //向后按钮
      6   $('span.next').click(function(){ //绑定click事件
      7       clearInterval(timer);
      8      var container = $(this).parents('div.container');  //根据当前点击元素获取到祖先元素(最外层的idv) container 
      9      var imgBox = container.find('div.imgbox');  //获取装图片的盒子
     10      var imgContainer = container.find('div.img_container'); //获取展示图片的显示屏
     11      var iWidth = imgContainer.width(); //获取显示屏的宽度
     12      var len = container.find('li').length;  //获取列表的个数
     13      var pageCount = Math.ceil(len/i);   // 分为多少版,一定要注意细节啊,这里的是Math.ceil(),向上取整(只要不是整数,就往大的方向取最小的整数)
     14      if(!imgBox.is(":animated")){    //判断装图片的盒子是否正在处于动画
     15         if(page == pageCount){  //已经到最后一个版面了,如果再向后,必须跳转到第一个版面
     16            imgBox.animate({left:'0px'},'slow'); //通过改变left值,跳转到第一个版面
     17            page = 1;    
     18         }else{
     19            imgBox.animate({left:'-='+iWidth},'slow');
     20            page++;    
     21         }     
     22      } 
     23      container.find('.circle span').eq((page-1)).addClass('current').siblings().removeClass('current'); 
     24   });
     25   //向前按钮
     26   $('span.prev').click(function(){
     27       clearInterval(timer);
     28      var container = $(this).parents('div.container');
     29      var imgBox = container.find('div.imgbox');
     30      var imgContainer = container.find('div.img_container');
     31      var iWidth = imgContainer.width();
     32      var len = container.find('li').length; 
     33      var pageCount = Math.ceil(len/i);
     34      if(!imgBox.is(":animated")){
     35        if(page == 1){
     36           imgBox.animate({left:'-='+iWidth*(pageCount-1)},'slow');
     37           page = pageCount;   
     38        }else{
     39           imgBox.animate({left:'+='+iWidth},'slow');
     40           page--;   
     41        }     
     42      } 
     43      container.find('.circle span').eq((page-1)).addClass('current').siblings().removeClass('current');
     44   });
     45   
     46   //下面的圆环的鼠标经过事件
     47   $('.circle span').click(function(){
     48      var count = $('.circle span').index(this); 
     49      var container = $(this).parents('div.container');
     50      var imgBox = container.find('div.imgbox');
     51      var imgContainer = container.find('div.img_container');
     52      var iWidth = imgContainer.width();
     53      var len = container.find('li').length; 
     54      var pageCount = Math.ceil(len/i);
     55      if(!imgBox.is(':animated')){
     56         imgBox.animate({left:-iWidth*count},500);     
     57      }
     58      $(this).addClass('current').siblings().removeClass('current');
     59   });
     60 });
     61 
     62 window.onload = startMove;
     63 var timer = null;
     64 function startMove(){
     65      var container = $('div.container');
     66      var imgBox = container.find('div.imgbox');
     67      var imgContainer = container.find('div.img_container');
     68      var iWidth = imgContainer.width();
     69      var pPage = 1;
     70      /*var offLeft = imgContainer.offset().left;
     71      var offLeftImg = Math.round(1800-offLeft);*/
     72 
     73      timer = setInterval(function(){
     74      
     75           /*if(imgBox.css('left') == -1800+'px'){
     76                 imgBox.animate({left:'0px'});
     77               }else{imgBox.animate({left:'-='+iWidth});}*/  //这中方法不错的哦
     78     /*if(imgBox.offset().left <= -1200){
     79                 
     80                 imgBox.animate({left:'0px'});
     81             
     82     }
     83               else{imgBox.animate({left:'-='+iWidth});} */  //这种方法不可取
     84               if(imgBox.css('left') == -1800+'px'){
     85                 imgBox.animate({left:'0px'});
     86                 pPage = 1;
     87               }else{
     88                 imgBox.animate({left:'-='+iWidth});
     89                 if(pPage == 4){
     90                   pPage = 1;    
     91                 }else{
     92                   pPage++;
     93                 }
     94               }
     95     /*var imgIndex = Math.abs(parseInt(imgBox.css('left')))/iWidth;
     96     $('.circle span').eq((imgIndex+1)).addClass('current').siblings().removeClass('current');*/
     97     $('.circle span').eq(pPage-1).addClass('current').siblings().removeClass('current');
     98      
     99 },3600);    
    100 }
    101 </script>

    左右两个按钮display为none,当鼠标移入祖先元素container时,就会显示出来,当鼠标移入按钮时,透明度增加(即表示越亮,越接近图片或颜色本来的亮度。)

    图片下面的索引小圆也有点击效果。点击哪个,哪个就是选中状态,同时上面的板块跟着切换到那一版面。

    显示效果为:

    移入container:

    移入按钮:

  • 相关阅读:
    小数据池以及深浅拷贝
    字典的初识,了解
    元组:认识,索引 切片
    列表的认识,嵌套,增删改查
    bool、字符串方法、for循环
    字符串格式化输出、while循环、运算符.
    Python的基础知识与历史应用
    git错误:error: failed to push some refs to 'https://...'
    golang中gin框架使用logrus
    golang中如何监控多个goroute协程是否执行完成
  • 原文地址:https://www.cnblogs.com/hl-520/p/4250690.html
Copyright © 2011-2022 走看看