zoukankan      html  css  js  c++  java
  • 关于轮播图,我知道的不多。

      关于轮播图,我确实是知道的不多,想来想去就只是那么的多,。

      不过我还是打算将自己知道的写出来,首先轮播图的布局,我先来上一张照片

      简单的布局,视窗中我能见到的只有一张照片和左右两个按钮还有下面两个按钮,视窗的大小就是单张图片的大小,几个按钮用position定位的方式将其定位到想要的位置了,那么四副图片的直接父元素的宽度是多少呢,那就是四副图片的宽度相加的总和,一定的让图片display:block;这样才能去掉图片默认距离,。

      在给图片float:left,在让最外层的盒子超出部分隐藏就可以了,。这样布局就算完成了。

      在来说说用jquery怎么简单的写出想要的效果。

      首先我们轮播图是怎样的效果呢,试想一下以前我们用的那种老式的胶卷的相机,每按一下

    快门,相机的胶卷就走一下,对了就是这种效果,。

      先上上代码

      

    var num=0;
            $(".buttons a").click(function(){
                num = $(this).index();
                var ml=num*-600+"px";
                $(".pic").animate({"margin-left":ml},500)
                $(this).addClass("red").siblings().removeClass("red");
                return false;            
            })

      简单的解释一下这段代码,。首先申明一个变量var num=0;赋值是0,为什么是0呢,可以把这个当成是a的索引值,索引是从0开始的,所以先赋值为0;接着

    当点击a标签的时候,获得当前a标签的索引,接着,在来获得图片外层盒子距离左边的距离,为了由动画效果,采用了.animate()方法,。为了让下面的按钮只是在点击当前按钮的时候才添加背景颜色,让其他的去掉颜色,这里用到的代码是$(this).addClass("red").siblings().removeClass("red");这段代码的意思是,给点击的这个元素添加类名,在去除选中的这个元素的其他的元素的类名就可以了,那最后为什么要添加return false;因为我们点击的是a元素,a是一个链接,是会刷新页面的,所以得加上return false;好了下面的按钮就可以了

    在来看看,左右按钮

    $(".next").click(function(){
                console.log(num);
                if(num<3){
                    num=num+1;
                }else{
                    num=0
                }
                var ml2 =num*-600 +"px";
                $(".pic").animate({"margin-left":ml2},500);
                $(".buttons a").eq(num).addClass("red").siblings().removeClass("red");
                return false;
            })
            $(".prev").click(function(){
                if(num>0){
                    num=num-1;
                }else{
                    num=3
                }
                var ml1 =num*-600 +"px";
                $(".pic").animate({"margin-left":ml1},500);
                $(".buttons a").eq(num).addClass("red").siblings().removeClass("red");
                return false;
            })

      无论是点击左边的按钮还是右边的按钮我们都得做一下if  else判断,。判断完之后我们所得到的margin-left值还是当前元素的索引乘以单张图片的宽度,。最后加上$(".buttons a").eq(num).addClass("red").siblings().removeClass("red");就可以实现点击左右按钮的时候控制下面按钮的状态了

    这是暂时实现轮播图需要做的一下小小的事情,。

      海南岛,感谢川藏神兽毛琦拍的照片

  • 相关阅读:
    2
    作业5
    实验十
    作业 5 指针应用
    九九乘法表
    实验七(课堂练习)
    实验六 数组 (2)
    实验六 数组
    课堂实验5(求从m到n之间(包括m和n)所有素数的和)
    课堂实验5-2
  • 原文地址:https://www.cnblogs.com/hopeelephant/p/6107401.html
Copyright © 2011-2022 走看看