zoukankan      html  css  js  c++  java
  • js 实现图片间隔循环轮播以及没有间隔的循环轮播

    链接地址:http://blog.sina.com.cn/s/blog_75cf5f32010199dn.html

    最近做了个图片循环轮播的功能。就是几张图片不断的循环滚动显示。

    感觉这个方法不错所以把实现过程记录下来:
    图片间隔循环轮播:
    1、html里面把要进行轮播的图片用一个容器包起来,用js来控制这个容器滚动,当然最外面的容器要设置overflow:hidden;。
    2、css里面控制这个容器的位置,实现滚动就需要用到定位。
    3、js里面利用jquery的animate动画函数实现滚动。
     
    js列子:
    var Ptop = -100; 
    function ceshi () {
    $('#cesji .p1').animate({top: Ptop}, {
    duration: 400,
    complete: function () {
    Ptop = Ptop - 106;
    if (Ptop == -524) {
    Ptop = 6;
    $('#cesji .p1').css('top', '112px');
    }
    });
    }
    var qinghcu = setInterval(ceshi, 3000);
     
    没有间隔的循环轮播:
    没有间隔的循环轮播和有间隔的循环轮播步骤差不多,只是定时器不是间隔多久移动一次,而是要执行完一次后马上执行第二次,这里我们最好是用超时定时器setTimeout()方法。一开始执行一次,然后再执行的函数体里面再次调用该定时器,这样就会不断地调用那个执行移动的函数,从而实现不断移动。。。。
    用juqery动画的列子:
    var sudu = 3;
    var hzmtQingChu;
    function ceshi () {
    $('.aa2').animate({left:sudu}, {
    duration : 120,
    complete : function() {
    sudu = sudu + 3;
    if (sudu == 300) {
    //alert('a');
    sudu = 3;
    $('.aa2').css('left', '3px');
    }
    hzmtQingChu = setTimeout(ceshi); //目标移动完后再次调用该移动函数
    }
    });
    }
     
     hzmtQingChu = setTimeout(ceshi, 60);
     
    原生态列子:
    var sudu = 1;
    var hzmtQingChu;
    function ceshi () {
    $('.aa').css('left', sudu);
    sudu = sudu + 1;
    if (sudu == 600) {
    $('.aa').css('left', '1');
    sudu = 1;
    }
    hzmtQingChu = setTimeout(ceshi);//目标移动完后再次调用该移动函数
    }
     
     
    hzmtQingChu = setTimeout(ceshi);
     
    这里图片放的位置有点技巧,假如我们这个容器里面显示的是三张图片,但是一共有5张图片轮播,下面看看方的位置:
     5, [1, 2, 3], 4,5,1, 2
    5, 1, [2, 3, 4],5,1, 2
    5, 1, 2, [3, 4, 5],1,2
    5,1,2,3[4, 5, 1], 2, 
    5,1,2,3,4[5,1,2]      ==> 这个时候换下面最开始的状态
    [5, 1, 2], 3, 4,5,1, 2   [回到最开始的状态]

    []括号里面的代表你的容器里面显示的3张图片 
    如果一件事情你觉得难的完不成,你可以把它分为若干步,并不断寻找合适的方法。最后你发现你会是个超人。不要给自己找麻烦,但遇到麻烦绝不怕,更不要退缩。 电工查找电路不通点的最快方法是:分段诊断排除,快速定位。你有什么启示吗? 求知若饥,虚心若愚。 当你对一个事情掌控不足的时候,你需要做的就是“梳理”,并制定相应的规章制度,并使资源各司其职。
  • 相关阅读:
    JPA的查询语言—使用构造器
    Servlet3.0使用注解定义Servlet
    jQuery操作<input type="radio">
    JPA的查询语言—使用原生SQL
    jQuery动态添加<input type="file">
    JPA的查询语言—JPQL的关联查询
    jQuery操作<select>
    Servlet3.0异步处理
    jQuery操作<input type="checkbox">
    mysql binlog二进制日志详解
  • 原文地址:https://www.cnblogs.com/wvqusrtg/p/5105420.html
Copyright © 2011-2022 走看看