选中并取消选中复选框

时间:2015-11-24 22:55:01

标签: javascript html checkbox

为什么当我选中复选框时,当我取消选中它没有任何意义时它可以正常工作

Checked Unchecked

<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>

2 个答案:

答案 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) {