作家
登录

JQuery slideshow的一个小问题(如何发现及解决过程)

作者: 来源:www.28hudong.com 2013-03-30 00:10:30 阅读 我要评论

第一阶段,试用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插件实现鼠标经过图片右侧显示大图的效果(类似淘宝)

这个插件的名字elevatezoom,网址为http://www.elevateweb.co.uk/image-zoom,在github上的项目首页为https://github.com/elevateweb/elevatezoom,建议去github下载,这个网速比较快。 实现这个效果你需要准备两张>>>详细阅读


本文标题:JQuery slideshow的一个小问题(如何发现及解决过程)

地址:http://www.17bianji.com/kaifa2/JS/22368.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)