手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JQuery slideshow的一个小问题(如何发现及解决过程)
JQuery slideshow的一个小问题(如何发现及解决过程)
摘要:第一阶段,试用slideshow在做一个网页homepage的时候,想用slideshow[1]做图片切换效果,其中js部分代码如下:复制代...

第一阶段,试用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);

});

【JQuery slideshow的一个小问题(如何发现及解决过程)】相关文章:

jquery 构造函数在表单提交过程中修改数据

javascript实现可拖动变色并关闭层窗口实例

JQuery中两个ul标签的li互相移动实现方法

JQuery实现带排序功能的权限选择实例

VBScript版代码高亮

JQuery中属性过滤选择器用法

JS中Eval解析JSON字符串的一个小问题

JavaScript中使用Math.PI圆周率属性的方法

两个SUBMIT按钮,如何区分处理

JavaScript实现斗地主游戏的思路

精品推荐
分类导航