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

转载于:https://www.cnblogs.com/bent/archive/2013/02/06/2900570.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值