zoukankan      html  css  js  c++  java
  • JQuery slideshow的一个小问题

    第一阶段,试用slideshow

    在做一个网页homepage的时候,想用slideshow[1]做图片切换效果,其中js部分代码如下:

    function next_slide() {
      var $active = $('#bitware-overlay img.active');
      if ($active.length == 0)
        $active = $('#bitware-overlay img:last');

      var $next = $active.next().length ? $active.next() : $('#bitware-overlay img:first');

      $active.addClass('last-active');
      $next.addClass('active');
      $next.css({opacity: 0.0});
      $next.animate({opacity: 1.0}, 1500,function(){
        $active.removeClass();
      });
    }

    $(function() {
      setInterval("next_slide()", 4000);
    });

    第二阶段,发现问题

      在打开页面所以的正常测试都没问题,最后领导发现,当浏览器同时打开多个tab,停留他tab中的页面一段时间后,会出现图片是最后一张图片,然后变化为第一张图片,刚变化(有淡入的的效果)完成,就突然跳转到最后一张图片。当我改为:

    function next_slide() {
      var $active = $('#bitware-overlay img.active');
      if ($active.length == 0)
        $active = $('#bitware-overlay img:last');

      var $next = $active.next().length ? $active.next() : $('#bitware-overlay img:first');

      $active.addClass('last-active');
      $next.addClass('active');
      $next.css({opacity: 0.0});
      $next.animate({opacity: 1.0}, 1500);

      $active.removeClass();
      setTimeout("next_slide()", 4000);
    }

    $(function() {
      setTimeout("next_slide()", 4000);
    }); 

      发现停留在其它tab后,回到页面时,图片显示的顺序正确,间隔时间也正确,4000毫秒,但是显示出来的时候,是直接跳转式,也不是淡出形状,似乎animate的1500毫秒没有启动任何效果。过一段时间会恢复正常,但是这种现象的时间长短,跟停留在别的tab时间长短似乎成正比。

    第三阶段,解决问题

    最后发现原因,是因为jquery的本质是单线程[2],当停留在别的tab中,任务中将next_silde()函数积压过多所致。最后找到的解决方案[4]如下:

    function next_slide() {
      var $active = $('#bitware-overlay img.active');
      if ($active.length == 0)
        $active = $('#bitware-overlay img:last');

      var $next = $active.next().length ? $active.next() : $('#bitware-overlay img:first');

      $active.addClass('last-active');
      $next.addClass('active');
      $next.css({opacity: 0.0});
      $next.animate({opacity: 1.0}, 1500,function(){
      $active.removeClass();
        setTimeout("next_slide()", 4000);
      });
    }

    $(function() {
      setTimeout("next_slide()", 4000);
    });

    参考目录

    [1]http://www.360doc.com/content/10/1129/17/573136_73477931.shtml

    [2]http://www.phpv.net/html/1700.html

    [3]http://www.phpweblog.net/rainman/archive/2009/01/05/6267.html

    [4]http://stackoverflow.com/questions/10671284/javascript-jquery-setinterval-animation

  • 相关阅读:
    Android应用开发学习笔记之事件处理
    [置顶] 炎炎夏日,给你一次极爽的开发体验!——统一开发环境功能升级优化,正式上线V2.0!
    POJ 3468 A Simple Problem with Integers (伸展树区间更新求和操作 , 模板)
    京东商城发现了一枚Bug
    iOS_40_核心动画
    SVN——库合并
    ORACLE 8i 遇到报错:ORA-01631: max # extents (505) reached in table
    HDU 5366:The mook jong 递推
    Linux平台下裸设备的绑定:
    CSP:使用CryptoAPI解码X509证书内容
  • 原文地址:https://www.cnblogs.com/bent/p/2900570.html
Copyright © 2011-2022 走看看