我构建了一个表单,可以从MySQL数据库中选择数据,并且所选行的所需字段将显示在表单的输入字段中。然而,这种形式是动态的,你可以有多种形式的相同形式。自动填充动态生成的表单
如果生成两个或多个表单,则只会自动填充第一个表单。我希望每个表单在从数据库中选择一行时自动填充其对应的输入字段。
下面是代码:
<?php
$start=1;
$end= $_POST['item']; echo'<br>';
for($start;$start<=$end;$start++){
require("connect.php");
$sql = "(SELECT * FROM drug_name)";
$result = mysqli_query($conn, $sql);
?>
<form align="center" method="post" action="transaction.php">
Name:
<select align="right" name="inputname[]" onchange="showunit(this.value); showqty(this.value)"
value="inputvalue[]">
<option selected="selected" value="0">S/N Select drug --</option>
<?php while($row = $result->fetch_assoc()){ ?>
<option value='<?php echo $row['SN']; ?>'><?php
echo$row['Drug_Item_Name']?></option>
<?php
}
?>
</select>
<td align="right">Stock Level:</td>
<td><input type="text" name="input3[]" placeholder="Enter QTY" size="5" id="displayqty"></td>
</tr>
<?php echo '<br>'; ?>
<?php }
?> </form>
这是代码,以使AJAX代码:
<script>
function showqty(str) {
if (str == "") {
document.getElementById("displayqty").value = "";
return; `
} else {
if (window.XMLHttpRequest) {
// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp = new XMLHttpRequest();
} else {
// code for IE6, IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
document.getElementById("displayqty").value = xmlhttp.responseText;
}
}
xmlhttp.open("GET","qtydisplay.php?q2="+str,true);
xmlhttp.send();
}
}
</script>
这是AJAX代码来获取从MySQL数据库中的数据:
<?php
$q2 = intval($_GET['q2']);
include("connect.php");//connection to database
mysqli_select_db($conn,"ajax_demo");
$sql="SELECT Qty_Stocked FROM drug_name WHERE SN = '".$q2."' LIMIT 1";
$result = mysqli_query($conn,$sql);
while($row = mysqli_fetch_array($result)) {
echo $row['Qty_Stocked'];
}
mysqli_close($conn);
?>
SQL开始时出错 - 从字符串中删除圆括号。除此之外,我看不到具体的问题。这个脚本中有什么特别的不起作用? – halfer
for()'循环很奇怪 - 你给它一个循环外的起始值。把它移到里面,这样:'for($ start = 1; ...'。 – halfer
@Halfer,谢谢你的回应,只有第一种形式自动填充输入字段,我希望每个表格都包含标签以便能够从数据库中选择数据并自动填充其相应的输入字段 – walex