繁体   English   中英

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

[英]Reset input fields when adding a new row to a table using JavaScript

在我的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函数,该函数向表中添加了一行。

我需要向脚本添加什么内容,以便将其复制而无需输入字段中的文本?

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

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

这样,您可以控制进入newcell的内容。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM