2010-08-02 87 views
1

我想實現以下 - 從每個問題的列表中選擇4個多選答案我需要顯示用戶是否通過顯示是否正確一旦單選按鈕被按下,它就是正確的或不正確的。單選按鈕 - 顯示基於與jQuery的選中按鈕的DIV

這是一個問題的例子:

<ol> 
<li id="question_one"> 
<p><input type="radio" name="question_1" value="answer_1" />Corn</p> 
<p><input type="radio" name="question_1" value="answer_2" />Cotton</p> 
<p><input type="radio" name="question_1" value="answer_3" />Rice</p> 
<p><input type="radio" name="question_1" value="answer_4" />Soybeans</p> 
</li> 
</ol> 

<div id="q1_answer_1" class="show_answer">Corn 11.0%</div> 
<div id="q1_answer_2" class="show_answer">Cotton 2.5%</div> 
<div id="q1_answer_3" class="show_answer">Rice 11.0%</div> 
<div id="q1_answer_4" class="show_answer">Soybeans 7.0%</div> 

,並將所得的jQuery:

$("#question_one input:radio:eq(answer_1)").click(function(){ 
$("#q1_answer_1").show(100); 
}); 

$("#question_one input:radio:eq(answer_2)").click(function(){ 
$("#q1_answer_2").show(100); 
}); 

$("#question_one input:radio:eq(answer_3)").click(function(){ 
$("#q1_answer_3").show(100); 
}); 

$("#question_one input:radio:eq(answer_4)").click(function(){ 
$("#q1_answer_4").show(100); 
}); 

我相信,這將無法工作,因爲eq()將只數值工作?是否有相當於eq()的輸入值?或者其他建議如何可以工作?

非常感謝

回答

4

如果你希望它是多一點通用的,你可以做它的基礎上的價值,就像這樣:

$("#question_one :radio[name=question_1]").change(function() { 
    $("div.show_answer").hide(); 
    $("#q1_" + $(this).val()).show(100); 
});​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​​ 

You can give it a try here,或者如果您需要更通用的,說你有多個問題,只是在一個容器包裝每個HTML的塊以上,例如<div class="question"></div>那麼你可以做這樣的事情:

$(".question :radio[name=question_1]").change(function() { 
    $(this).closest(".question").find("div.show_answer").hide() 
      .filter("[id$='" + $(this).val() +"']").show(100); 
});​ 

You can test that version here,它將適用於多個問題,無需爲每個問題重複您的代碼。


註釋:

$(this).closest('li').find(':radio').attr('disabled', true); 

或者,如果你想:到第一後殺死它點擊你有幾種選擇,你可以通過添加這給處理程序(test here)禁用它們(test here):

$(this).closest('li').find(':radio').unbind('change'); 
+0

這太棒了,謝謝!唯一的事情是,用戶可以檢查一個收音機盒,看到隱藏的DIV的內容,然後按另一個,然後看到該DIV的內容,等等。有什麼辦法可以修改,只需要第一個單選按鈕單擊,顯示DIV,然後再接受無線電點擊? – Dave 2010-08-02 10:33:59

+0

@Dave - 是的,添加到答案,我給你兩個選項,你可以禁用它們來防止選擇更改*或*只是解除處理程序,以便選擇可以更改,但顯示的div不。 – 2010-08-02 10:35:02

+0

嗯,這太神奇了,非常感謝!完美的作品。謝謝。 – Dave 2010-08-02 11:02:50

0

嘗試使用僞選擇:檢查,像這樣: $(「#question_one輸入:檢查」)......

+0

謝謝@Calle,但我與尼克的解決方案一起去了。 – Dave 2010-08-02 11:03:34

相關問題