Вы сохраняете значение, не сравнивая
Оператор if
if( document.getElementsByName("aForm[0].info")[0].checked = true )
должен быть
if( document.getElementsByName("aForm[0].info")[0].checked == true )
заметить ==
А что с else?
else document.getElementsByName("aForm[0].info")[0].checked = false;{
Вы рассматриваете это как else if (), иначе там нет оператора.
Ваш код долженвыкидывать ошибки JavaScript при запуске.
И нет такой вещи, как включена, она просто отключена, true / false.
Ваш код должен выглядеть как
function test(obj) {
if (document.getElementsByName("aForm[0].info")[0].checked = true) {
document.getElementsByName("aForm[0].gender")[0].disabled = true;
}
else {
document.getElementsByName("aForm[0].gender")[0].disabled= false;
}
}
, и его можно упроститьвсего 3 строки:
function test(obj) {
document.getElementsByName("aForm[0].gender")[0].disabled = document.getElementsByName("aForm[0].info")[0].checked;
}
и заставить его работать без имен элементов:
<script>
function test(cb){
cb.parentNode.parentNode.getElementsByTagName("select")[0].disabled = cb.checked;
}
</script>
<table>
<tbody>
<tr>
<td><input type="checkbox" onclick="test(this);"></td>
<td><select><option>a</option><option>b</option></select></td>
</tr>
<tr>
<td><input type="checkbox" onclick="test(this);"></td>
<td><select><option>a</option><option>b</option></select></td>
</tr>
</tbody>
</table>
Примечание: parentNode.parentNode обязательно нарушается при изменении структуры страницы.:)