为什么当我选中复选框时,当我取消选中它没有任何意义时它可以正常工作
<form method="get">
<table id="row">
<tr><th colspan="2" >Location</th></tr>
<tr><td>Country:</td><td><select id="country" name ="country" style="width:200px"></select></td></tr>
<tr><td>City:</td><td><select name ="city" id ="state"></select></td></tr>
<script language="javascript">
populateCountries("country", "state");
</script>
<tr><td></td><td><input onclick="myFunction()" type="checkbox" name="manualentry" value="manualentry" >Manual Entry</td></tr>
<script>
var table = document.getElementById("row");
function myFunction() {
if (document.getElementsByTagName('manualentry').checked = true) {
document.getElementById("row").deleteRow(2);
var row = table.insertRow(2);
var cell1 = row.insertCell(0);
var cell2 = row.insertCell(-1);
cell1.innerHTML = "City:";
cell2.innerHTML = '<input type="text" >';
} else {
document.getElementById("row").deleteRow(2);
var row = table.insertRow(2);
var cell1 = row.insertCell(0);
var cell2 = row.insertCell(1);
cell1.innerHTML = "City:";
cell2.innerHTML = '<select name ="city" id ="state"></select>';
}
}
</script>
<tr ><td colspan="2" align="right" > <input type="submit" value="Submit"></td></tr>
</table>
</form>
答案 0 :(得分:1)
一些事情。 GetElementsByTagName
是错误的函数调用,该方法用于通过实际的HTML标记获取元素数组。请改用GetElementsByName
。此外,此调用将返回一个数组,因此您需要指定它是哪个索引(它将是索引0)。由于checked
已经是布尔值,因此您无需指定== true
。
替换if (document.getElementsByTagName('manualentry').checked = true)
if (document.getElementsByName('manualentry')[0].checked)
答案 1 :(得分:0)
您在if条件中忘记了=
:
if (document.getElementsByTagName('manualentry').checked = true) {
试
if (document.getElementsByTagName('manualentry').checked == true) {