您好我正在尝试在选中复选框时禁用下拉菜单,并且取消选中该复选框时启用下拉列表。下面是我的javascript,当我选中复选框时它正在工作,但它不会让我取消选中该复选框:
<script type="text/javascript">
function test(obj){
if (document.getElementsByName("aForm[0].info")[0].checked = true) {
alert("here");
document.getElementsByName("aForm[0].gender")[0].disabled = true;
}
else document.getElementsByName("aForm[0].info")[0].checked = false;{
document.getElementsByName("aForm[0].gender")[0].enabled = true;
}
}
</script>
这是我的jsp
<logic:iterate id="data" name="aForm" property="testList">
<tr>
<td>
<html:checkbox indexed="true" name="aForm" styleId="something" property="info" onclick="test(this)"/>
</td>
<td>
<html:select name="aForm" indexed="true" property="unit" styleId="dropdown">
<html:optionsCollection name="aForm" property="selectGender" value="value" label="label"/>
</html:select>
>
</td>
</tr>
</logic:iterate>
答案 0 :(得分:1)
您正在存储值,而不是比较
if语句
if( document.getElementsByName("aForm[0].info")[0].checked = true )
应该是
if( document.getElementsByName("aForm[0].info")[0].checked == true )
注意 ==
与其他人有什么关系?
else document.getElementsByName("aForm[0].info")[0].checked = false;{
你把它当作其他的if()来对待,否则那里没有声明。
您的代码在运行时应该抛出JavaScript错误。
并且没有启用此功能,它只是禁用,是/ true。
您的代码应该是
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将被绑定。 :)