2009-11-25 91 views
0

我有4個單選按鈕,對應4個不同的div。我想淡出當前的div,然後在新的選定的一個。現在它的工作,但只是在圖像之間淡出。顯示/隱藏基於收音機點擊類div

還有一種方法可以根據收音機的類而不是值來更改div嗎?

代碼我目前有:

<input type="radio" name="myRadio" class="myDiv_1" value="myDiv_1" />Image1<br /> 
<input type="radio" name="myRadio" class="myDiv_2" value="myDiv_2" />Image2<br /> 
<input type="radio" name="myRadio" class="myDiv_3" value="myDiv_3" />Image3<br /> 

<div id="myDiv_1" class="shade" style="display:block;"><img>TEXT BELOW IMAGE</div> 
<div id="myDiv_2" class="shade" style="display:block;"><img>TEXT BELOW IMAGE</div> 
<div id="myDiv_3" class="shade" style="display:block;"><img>TEXT BELOW IMAGE</div> 

<script type="text/javascript"> 
$(document).ready(function(){ 
    $('input[name="myRadio"]').click(function() { 
     var selected = $(this).val(); 
     $(".shade").fadeOut("slow"); 
     $('#' + selected).fadeIn("slow"); 
    }); 
}); 
</script> 

回答

0

是的,你可以使用jQuerys attr方法獲取類對象:

var selected = $(this).attr("class"); 
1

只需更換

var selected = $(this).val(); 

var selected = $(this).attr("class"); 

和褪色的依賴於inputclass屬性div

此外,我建議使用這個(這應該是更快)的

$("div.shade:visible").fadeOut("slow"); 

代替

$(".shade").fadeOut("slow"); 
2

「我想淡出當前的div,然後在新的選定的一個」

使用淡出()回調函數:

$(".shade").fadeOut("slow", function() { 
    $('#' + selected).fadeIn("slow"); 
}); 
+0

回調不工作。當一個單選按鈕被點擊時,它會淡入到新的div中,但是新選定的div會淡出然後返回。它基本上會衰落很多次。如果需要,我可以鏈接到一個例子。 – 2009-11-26 00:46:54