使用JavaScript向表中添加新行时重置输入字段

时间:2017-08-29 10:43:10

标签: javascript php html html-table html-input

在我的HTML页面上,表单中有一个表格。表的第一行是列的标签,其余行包含输入文本字段。

在表格下方,有一个操作JavaScript函数的按钮,它复制了表格末尾的第一行。

问题是文本也从第一行字段复制到新添加的行字段。相反,我想清除新添加的行字段中的文本。我怎么能这样做?

这是我的代码:

<form action="update.php" method="post" enctype="multipart/form-data">
<table id="addresses" class="form" border="1">
<tbody>
  <tr>
    <p>
      <th>

      </th>
      <th>
        <label for='UPDATE_NAME'>Name</label>
      </th>
      <th>
        <label for='UPDATE_NUMBER'>Phone Number (With Country Code)</label>
      </th>
      <th>
        <label>Address (House No., Street, City, State, ZIP Code, P.O. Box)</label>
      </th>
    </p>
  </tr>
  <?php
                            for ($i = 0; $i < count($addresses); $i++) {
                                $id = str_pad($i, 2, '0', STR_PAD_LEFT);
                                echo "<tr>";
                                echo "<p>";
                                echo "<td>";
                                echo "<input type='checkbox' name='chk[]' />";
                                echo "</td>";
                                echo "<td>";
                                echo "<input type='text' name='UPDATE_NAME[]' value='".$names[$id]['S']."' />";
                                echo "</td>";
                                echo "<td>";
                                echo "<input type='tel' name='UPDATE_NUMBER[]' value='".$numbers[$id]['S']."' />";
                                echo "</td>";
                                echo "<td>";
                                echo "<input type='text' name='UPDATE_ADDRESS[]' value='".$addresses[$id]['S']."' />";
                                echo "</td>";
                                echo "</p>";
                                echo "</tr>";
                            }
                        ?>
</tbody>
</table>
<p>
    <input type="button" value="Add Address" onClick="addRow('addresses')" />
</p>
<script>
function addRow(tableID) {
  var table = document.getElementById(tableID);
  var rowCount = table.rows.length;
  if (rowCount < 10) {
    var row = table.insertRow(rowCount);
    var colCount = table.rows[0].cells.length;
    for (var i = 0; i < colCount; i++) {
      var newcell = row.insertCell(i);
      newcell.innerHTML = table.rows[1].cells[i].innerHTML;
    }
    document.getElementById("APP_UPDATE_NAME[" + rowCount + "]").reset();
  } else {
    alert("Maximum Branches Number is 10");
  }
}
</script>
<input type="submit" class="flat-button form" name="SUBMIT" value="Update Addresses" />
</form>

在上面的代码中,您可以看到带有标签的第一行,然后是一个PHP循环,它从PHP数组中添加信息。在表之后,您可以看到向表中添加行的JavaScript函数。

我需要将哪些内容添加到脚本中,以便在没有输入字段的文本的情况下复制它?

1 个答案:

答案 0 :(得分:2)

您可以手动设置新行的值,而不是复制它。像这样:

newcell.innerHTML = "<input type='...' name='...' value='...' />";

通过这种方式,您可以控制进入newcell的内容。

相关问题