国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JQuery slideshow的一個小問題(如何發(fā)現(xiàn)及解決過程)

2019-11-20 23:00:08
字體:
供稿:網(wǎng)友
第一階段,試用slideshow
在做一個網(wǎng)頁homepage的時候,想用slideshow[1]做圖片切換效果,其中js部分代碼如下:
復(fù)制代碼 代碼如下:

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);
});

第二階段,發(fā)現(xiàn)問題
在打開頁面所以的正常測試都沒問題,最后領(lǐng)導(dǎo)發(fā)現(xiàn),當(dāng)瀏覽器同時打開多個tab,停留他tab中的頁面一段時間后,會出現(xiàn)圖片是最后一張圖片,然后變化為第一張圖片,剛變化(有淡入的的效果)完成,就突然跳轉(zhuǎn)到最后一張圖片。當(dāng)我改為:
復(fù)制代碼 代碼如下:

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);
});

發(fā)現(xiàn)停留在其它tab后,回到頁面時,圖片顯示的順序正確,間隔時間也正確,4000毫秒,但是顯示出來的時候,是直接跳轉(zhuǎn)式,也不是淡出形狀,似乎animate的1500毫秒沒有啟動任何效果。過一段時間會恢復(fù)正常,但是這種現(xiàn)象的時間長短,跟停留在別的tab時間長短似乎成正比。
第三階段,解決問題
最后發(fā)現(xiàn)原因,是因為jquery的本質(zhì)是單線程[2],當(dāng)停留在別的tab中,任務(wù)中將next_silde()函數(shù)積壓過多所致。最后找到的解決方案[4]如下:
復(fù)制代碼 代碼如下:

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);
});
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 余庆县| 商河县| 义马市| 紫阳县| 安顺市| 格尔木市| 钟祥市| 镇原县| 化德县| 平和县| 两当县| 新余市| 高密市| 玉林市| 安化县| 阳东县| 泌阳县| 贵定县| 华池县| 佳木斯市| 闻喜县| 得荣县| 东辽县| 阿图什市| 中西区| 四平市| 铁岭县| 淅川县| 盐源县| 芒康县| 秀山| 永和县| 宜州市| 南华县| 乌兰察布市| 民乐县| 牙克石市| 武隆县| 普洱| 绥阳县| 涪陵区|