2013-04-15 43 views
-1

我正在使用下面的代碼來顯示一個大的全屏滑塊。我試圖做的是將.click函數替換爲timed事件,以便每個圖像在一段時間後(例如7秒)發生更改,而不是點擊鏈接。jquery更改.click函數自動更改

一直在這工作了半天,我仍然卡住,所以任何幫助,你可以提供將非常感激。

感謝

戴夫

jQuery(function($){ 
    $(document).ready(function(){ 

    $('.panorama .panorama-view').panorama360(); 
if ($('.panorama #thumbnails .thumbers a').length > 1) { // check if there are multiple panoramas 
    $('.panorama .panorama_controls a').click(function(ev) { 
     ev.preventDefault(); 
     $active = $('.panorama #thumbnails .thumbers a.active'); 
     if ($(this).hasClass('panorama_next')) { 
      if ($active.length == 0) $active = $('.panorama #thumbnails .thumbers a:last'); 
      $next = $active.parent().next('li'); 
      console.log($next); 
      if ($next.length > 0) { // check to see if it's not the first thumb 
       $('a:first',$next).trigger('click'); 
      } else { // load last panorama in the thumb stack 
       $('.panorama #thumbnails .thumbers:first a').trigger('click'); 
      } 
     } 
     else { 
      if ($active.length == 0) $active = $('.panorama #thumbnails a:first'); 
      $prev = $active.parent().prev('li'); 
      if ($prev.length > 0) { // check to see if it's not the first thumb 
       $('a:first',$prev).trigger('click'); 
      } else { // load last panorama in the thumb stack 
       $('.panorama #thumbnails .thumbers:last a').trigger('click'); 
      } 
     } 
    }); 
} else { // you can hide the controls because there is only one panorama loaded 
    $('.panorama .panorama_controls').hide(); 
} 
$('.panorama #thumbnails .thumbers a').click(function(ev) { 
    ev.preventDefault(); 
    if ($(this).hasClass('active')) return; 

    $('.panorama .preloader').show(); 
    $('#thumbnails .thumbers a').removeClass('active'); 
    $(this).addClass('active'); 
    $('.panorama .panorama-view').hide(); 
    $('.panorama .panorama-container').html($(this).next().html()); 
    $('.panorama .panorama-view').panorama360({ sliding_direction: 0 }); 
    $('h1.main-header').html($(this).data("title")); 
    $('.main-desc').html($(this).data("description")); 

}); 
$('.panorama .hotspot').fancybox({ 

     padding  : 0, 
     fitToView : true, 
     mouseWheel : false, 
     maxWidth: '600', 
     minHeight: '400', 

     autoCenter: true, 

     closeClick : false 
}); 

var pictures = [], 

    $thumbnails = $('#thumbnails'); 

    // jScrollPane 

$thumbnails.find('ul').width(function() { 
    var totalWidth = 0; 
    $(this).find('li').each(function() { 
     totalWidth += $(this).outerWidth(true); 
    }); 
    return totalWidth; 
}); 

$thumbnails.jScrollPane(); 

var jScrollPaneApi = $thumbnails.data('jsp'); 

$(window).bind('resize', function() { 
    jScrollPaneApi.reinitialise(); 
}); 

    }); // END doc ready 
    }); // END function 
+0

您的jQuery選擇器可以使用一些改進。 '$('。panorama #thumbnails .thumbers a')',爲什麼不直接給你的''上課? –

回答

0

而不是取代它,爲什麼不觸發點擊功能?

setTimeout(function() { 
    $('.panorama .panorama_controls a.panorama_next').click(); 
}, 7000); 
+0

嗨,德里克,感謝您的回覆。我將在哪裏放置這個功能,或者它會替換其他的東西? –

+0

@DaveHassall,只需將它粘貼到文檔就緒功能的末尾即可。無需替換任何東西。所有這些聲明都會告訴瀏覽器每7秒鐘點擊一次鏈接。然後您不必更改任何原始代碼。 –

+0

德里克很棒非常感謝你的幫助 –