Мониторинг, когда радиопроизводительная кнопка не контролирована
-
26-10-2019 - |
Вопрос
У меня есть приложение, которое показывает один div, когда выбран определенная радиопроизводительная кнопка, а затем скрывает этот Div, когда радиопроизводительная кнопка не выбирается. Проблема заключается в том, что событие изменения, прикрепленное к радионотке, вызывается только при проверке радиостанции, а не при проверке другого (не проводится предыдущим). Мой текущий код заключается в следующем:
<form name="newreport" action="#buildurl('report.filters')#" method="post">
<dl class="oneColumn">
<dt class="first"><label for="txt_name">Name</label></dt>
<dd><input type="text" name="name" id="txt_name" class="text" /></dd>
<dt><strong>Type</strong></dt>
<dt><input type="radio" name="type" id="rdo_list" value="list" checked="checked" /><label for="rdo_type" style="display:inline;">List</label></dt>
<dd>List a group of records</dd>
<dt><input type="radio" name="type" id="rdo_fields" value="fields" /><label for="rdo_fields" style="display:inline;">Field Breakdown</label></dt>
<dd>Breaks down distinct field values for comparison</dd>
<dt><input type="radio" name="type" id="rdo_history" value="history" /><label for="rdo_history" style="display:inline;">Historical Comparison</label></dt>
<dd>Provides record changes over a group of years for growth comparisons</dd>
<dt><input type="radio" name="type" id="rdo_breakdown" value="breakdown" /><label for="rdo_breakdown" style="display:inline;">Student Breakdown</label></dt>
<dd>Breaks down students by school, district or grade</dd>
<div class="reportyear">
<dt><label for="txt_year">Year to Report</label></dt>
<dd><input type="text" name="year" id="txt_year" class="text" value="#year(Rc.yearstart)#" /></dd>
</div>
<div class="date-spans" style="display:none;">
<dt><label for="txt_yearstart">Year Start</label></dt>
<dd><input type="text" name="yearstart" id="txt_yearstart" class="text" value="#evaluate(year(Rc.yearstart)-5)#" /></dd>
<dt><label for="txt_yearend">Year End</label></dt>
<dd><input type="text" name="yearend" id="txt_yearend" class="text" value="#year(Rc.yearstart)#" /></dd>
</div>
</dl>
</form>
<script type="text/javascript">
$(function(){
$('##rdo_history').change(function(e){
var isChecked = $(this).attr(checked);
var $datespan = $('form .date-spans');
var $year = $('form .reportyear');
if(isChecked){
$year.css({display:'none'});
$datespan.fadeIn('fast');
}else{
$datespan.css({display:'none'});
$year.fadeIn('fast');
}
});
});
</script>
Это кажется довольно простым сценарием, но событие вызывает только на Check Event, а не на событии Unchect. Кто -нибудь может сказать мне почему?
Решение
Обработайте событие изменения в радио -группе, а не на каждой кнопке. Затем посмотрите, какой из них проверяется.
Вот какой -то непроверенный код, который, надеюсь, показывает, о чем я говорю :) ...
$("input[name='type']").change(function(e){
if($(this).val() == 'history') {
$year.css({display:'none'});
$datespan.fadeIn('fast');
} else {
$datespan.css({display:'none'});
$year.fadeIn('fast');
}
});
Другие советы
Обратите внимание на это поведение при получении радио входных значений:
$('input[name="myRadio"]').change(function(e) { // Select the radio input group
// This returns the value of the checked radio button
// which triggered the event.
console.log( $(this).val() );
// but this will return the first radio button's value,
// regardless of checked state of the radio group.
console.log( $('input[name="myRadio"]').val() );
});
Так $('input[name="myRadio"]').val()
Не возвращает зарегистрированное значение радио ввода, как вы можете ожидать - оно возвращает значение первой радиопроизводительной кнопки.