zoukankan      html  css  js  c++  java
  • jQyery实现轮播器

    看到各大网站上都有一个轮播器的效果,自己不禁也想做一个,查了资料,看了轮播器的原理,慢慢的试着做了做,最终效果勉勉强强

    原理:如图,试想一下,若是将<ul>的width属性值设置的很宽,直到可以装下你所有的图片,而每一个图片又用<li>包着并且设置了左浮动。

    那么当我们向左移动ul的时候并且移动的距离为<li>的宽度,第二个<li>不就被移动到了<div>的窗口,这样一来图片不就被一张一张显示出来了吗?

    接下来我们在设置<div>的属性overflow:hidden,那么<div>窗口以外的图片不显示,只显示移动到当前窗口的图片,是不是又完美了一些,感觉快做好了是吧!

    说了一些原理,好了,直接上代码,记得引入jquery。

    这是div做的布局,做的时候记得加上边框,做后在删掉,这样便于测试

     1 <div class="slideShow">
     2     <div class="nav-t">
     3         <ul>
     4             <li><a href="#" target="_blank"><img src="images/1.png" alt=""></a></li>
     5             <li><a href="#" target="_blank"><img src="images/2.png" alt=""></a></li>
     6             <li><a href="#" target="_blank"><img src="images/3.png" alt=""></a></li>
     7             <li><a href="#" target="_blank"><img src="images/4.png" alt=""></a></li>
     8             <li><a href="#" target="_blank"><img src="images/5.png" alt=""></a></li>
     9         </ul>
    10         <div class="nav-b">
    11             <span class="active">1</span>
    12             <span>2</span>
    13             <span>3</span>
    14             <span>4</span>
    15             <span>5</span>
    16         </div>
    17     </div>
    18   </div>
    19   <script type="text/javascript" src="jquery-min.js"></script>
    20   <script type="text/javascript" src="lunbo.js"></script>

    接下来设置一下样式

     1 <style>
     2     .slideShow{
     3         border:0px solid blue;
     4         width:600px;
     5         height:450px;
     6         margin:50px auto;
     7         position:relative;
     8     }
     9     .nav-t{
    10         border:0px solid red;
    11         width:580px;
    12         height:430px;
    13         margin:8px auto;
    14         position:relative;
    15         overflow:hidden;
    16     }
    17     .nav-t ul{
    18         border:0px solid green;
    19         list-style:none;
    20         width:3000px;
    21         height:430px;
    22         margin:0;
    23         padding:0;
    24         position:relative;
    25     }
    26     .nav-t li{
    27         height:427px;
    28         width:580px;
    29         float:left;
    30     }
    31     .nav-b{
    32         position:absolute;
    33         top:390px;
    34         left:220px;
    35         cursor:default;
    36     }
    37     .nav-b span{
    38         margin-right:5px;
    39         border:1px solid red;
    40         padding:0 6px;
    41         border-radius:12px;
    42         color:#fff;
    43         background:rgba(132,125,119,0.5);
    44         cursor:pointer;
    45     }
    46     .nav-b span.active{
    47         background:rgba(0,0,0,0.8);
    48     }
    49   </style>

    用js实现点击轮播图片、自动轮播图片,鼠标移动上去停止轮播

     1 $(function(){
     2     
     3     $(function(){
     4     var slide=$(".slideShow"),
     5         navt=slide.find(".nav-t"),
     6         ul=navt.find("ul"),
     7         navbs=slide.find(".nav-b span"),
     8         onwidth=ul.find("li").eq(0).width(),    //获取ul下的li宽度
     9         timer=null,
    10         inow=0;
    11     navt.hover(function(){
    12             clearInterval(timer);    //鼠标移上去,清除掉自动轮播功能,即定时轮播
    13         },autoPlay);    
    14     navbs.on("click",function(){    //点击轮播事件
    15         var me=$(this);
    16             inow=me.index();        //此处变量用的与自动轮播函数里的相同,为的是能在随便点击后,自动轮播时按照我们点击了的继续向后轮播,这叫动态实时
    17         ul.animate({left:-inow*onwidth},0.01); //ul向左移动从而使得下一个li显示到div的当前窗口
    18         navbs.removeClass("active");            //清除掉上一个点击按钮的样式
    19         me.addClass("active");                    //为当前被点击的按钮添加第一个按钮样式
    20     });
    21     autoPlay();                    
    22     function autoPlay(){                    //自动轮播函数
    23     timer=setInterval(function(){            //开定时器
    24         inow++;
    25         if(inow==navbs.length){                //判断是否到了最后一张,若是到了,返回到第一张
    26             inow=0
    27             }
    28         navbs.eq(inow).trigger("click");    //根据定时的时间用span的索引自动调用click事件,trigger为jQuery的自动调用函数
    29         },3000);
    30     }
    31 
    32 });
    33 
    34 
    35 
    36 });

    看一下效果图?好的

    怎么样,要不你也做一个?

    异乡小龟
  • 相关阅读:
    Android Studio学习笔记(1)
    2019全国大学生电子设计大赛总结
    包与常用模块
    模块
    迭代器、生成器与递归调用
    叠加多个装饰器与有参数的装饰器。
    装饰器
    控制指针的移动、函数
    字符编码
    python 数据类型之列表、元组、字典、集合
  • 原文地址:https://www.cnblogs.com/scale/p/5370343.html
Copyright © 2011-2022 走看看