2012-10-18 115 views
0

我在我的網站上使用全屏圖像庫,但是我試圖設計縮略圖的樣式,使我能夠瀏覽不同的圖像。縮略圖是用JS文件生成的。我設法將它們設置爲三角形,具有正常和懸停狀態。爲縮略圖創建活動狀態

我的問題是,我想爲此添加一個ACTIVE,在顯示某些圖像時顯示黑色三角形。我怎樣才能做到這一點?

JS文件

<script type="text/javascript"> 
    var slider; 
    var images = [ 
     "images/productie/1.jpg", 
     "images/productie/2.jpg", 
     "images/productie/3.jpg", 
     "images/productie/4.jpg", 
     "images/productie/5.jpg" 
    ]; 
    var index = 0; 
    var transitionSpeed = 500; 
    var imageIntervals = 5000; 
    var startIntervals; 
    var intervalSetTime; 
    var contentOpen = false; 

    $(document).ready(function(){ 

     slider = $('#slider1').bxSlider({ 
      mode: 'fade', 
      controls: false, 
      pause: imageIntervals 
     }); 

     for (i=0;i<=images.length - 1;i++){ 
      $('#thumb-container').append('<a href="javascript:goToContent('+ i +')"><img src="'+ images[i] +'?size=thumb" alt="Image '+ i +'" /></a>'); 
     } 

     $(function() { 

      $.preload(images, { 
       init: function(loaded, total) { 
        $("#indicator").html("<img src='images/load.gif' />");   
       }, 

       loaded_all: function(loaded, total) { 
        $('#indicator').fadeOut('slow', function() { 
         $('#left-side').fadeIn('slow'); 
         $('#thumb-container').fadeIn('slow'); 

         $.backstretch(images[index], {speed: transitionSpeed}); 

         startIntervals = function(){ 
          intervalSetTime = setInterval(function() { 
          index = (index >= images.length - 1) ? 0 : index + 1; 
          $.backstretch(images[index]); 
          slider.goToNextSlide() 
         }, imageIntervals)}; 

         startIntervals();     
        }); 
       } 
      }); 
     }); 
    }); 

    function goToContent(slideNum){ 
     clearInterval(intervalSetTime); 
     index = slideNum; 
     $.backstretch(images[index]); 
     slider.goToSlide(slideNum); 
     if (contentOpen == false){ 
      startIntervals(); 
     } 
    }; 

    function showContent(){ 
     $('.content-bg').fadeIn('slow'); 
     clearInterval(intervalSetTime); 
     contentOpen = true; 
    }; 
    function closeContent(){ 
     $('.content-bg').fadeOut('slow'); 
     startIntervals(); 
     contentOpen = false; 
    }; 
    </script> 

CSS

#thumb-container{ 
    display:none; 
} 

#thumb-container img{ 
    float:left; 
    border:0; 
    width: 0; 
    height: 0; 
    margin:2px; 
    border-top: 20px solid transparent; 
    border-bottom: 20px solid transparent; 
    border-left: 20px solid #fff; 
} 

#thumb-container img:hover{ 
    float:left; 
    border:0; 
    width: 0; 
    height: 0; 
    border-top: 20px solid transparent; 
    border-bottom: 20px solid transparent; 
    border-left: 20px solid #000; 
    } 
+1

如果#thumb-container只包含一個img,請嘗試'#thumb-container:active img'。 –

+0

熙亞歷山大,那不起作用.. – Sebastian

+0

呃,那麼你是什麼意思的「主動」? ':active'是一個僞類,當你激活一個元素時(例如,按下鼠標按鈕)應用... –

回答

0

問題是由Shefqet Avdullau

回答的Javascript

var slider; 
var images = [ 
    "IMAGES LINK", 
    "IMAGES LINK", 
    "IMAGES LINK" 
]; 
var index = 0; 
var transitionSpeed = 500; 
var imageIntervals = 5000; 
var startIntervals; 
var intervalSetTime; 
var contentOpen = false; 

$(document).ready(function(){ 

    slider = $('#slider1').bxSlider({ 
     mode: 'fade', 
     controls: false, 
     pause: imageIntervals 
    }); 

    for (i=0;i<=images.length - 1;i++){ 
     $('#thumb-container').append('<a href="javascript:goToContent('+ i +')"><img src="'+ images[i] +'?size=thumb" alt="Image '+ i +'" /></a>'); 
    } 

    $(function() { 

     $.preload(images, { 
      init: function(loaded, total) { 
       $("#indicator").html("<img src='images/load.gif' />");    
      }, 

      loaded_all: function(loaded, total) { 
       $('#indicator').fadeOut('slow', function() { 
        $('#left-side').fadeIn('slow'); 
        $('#thumb-container').fadeIn('slow'); 

        /* added by Shefqet Avdullau */ 
        $('#thumb-container a').removeClass('current_anchor').eq(index).addClass('current_anchor'); 
        $.backstretch(images[index], {speed: transitionSpeed}); 

        startIntervals = function(){ 
         intervalSetTime = setInterval(function() { 
         index = (index >= images.length - 1) ? 0 : index + 1; 

         /* added by me */ 
         $('#thumb-container a').removeClass('current_anchor').eq(index).addClass('current_anchor'); 

         $.backstretch(images[index]); 
         slider.goToNextSlide() 
        }, imageIntervals)}; 

        startIntervals();      
       }); 
      } 
     }); 
    }); 
}); 

function goToContent(slideNum){ 
    clearInterval(intervalSetTime); 
    index = slideNum; 
    /* added by Shefqet Avdullau */ 
    $('#thumb-container a').removeClass('current_anchor').eq(index).addClass('current_anchor'); 

    $.backstretch(images[index]); 
    slider.goToSlide(slideNum); 
    if (contentOpen == false){ 
     startIntervals(); 
    } 
}; 

function showContent(){ 
    $('.content-bg').fadeIn('slow'); 
    clearInterval(intervalSetTime); 
    contentOpen = true; 
}; 
function closeContent(){ 
    $('.content-bg').fadeOut('slow'); 
    startIntervals(); 
    contentOpen = false; 
}; 

CSS

/* THUMB SECTION */ 

#thumb-container{ 
    display:none; 
} 

#thumb-container img{ 
    float:left; 
    border:0; 
    width: 0; 
    height: 0; 
    margin:2px; 
    border-top: 20px solid transparent; 
    border-bottom: 20px solid transparent; 
    border-left: 20px solid #fff; 
} 

/* added by Shefqet Avdullau */ 

#thumb-container a.current_anchor img, 

#thumb-container img:hover, 
#thumb-container img.displayed { 
    float:left; 
    border:0; 
    width: 0; 
    height: 0; 
    border-top: 20px solid transparent; 
    border-bottom: 20px solid transparent; 
    border-left: 20px solid #6bcade; 
} 
1

隨着對這個問題的最後澄清評論,我相信你應該添加和刪除相應的CSS類(如displayed)從縮略圖,使用JavaScript。並修改最後規則選擇是:

#thumb-container img:hover, #thumb-container img.displayed 
+0

Alexander我在哪裏可以找到所顯示的班級? – Sebastian

+0

這是一個CSS類。您將以imageElement.className =「顯示」的形式將它添加到圖像中。更多關於這裏[這裏](http://www.htmldog.com/guides/cssintermediate/classid/) –

+0

你提到的鏈接不起作用? – Sebastian