我正在尝试运行一个将ID存储在隐藏的输入标记中的表单,以便可以使用php在下一页中检索它。由于某种原因,我无法使用php文件检索值。回呼orderId.value和订单号工作正常。
main_page.php
<script>
function EditValues(orderNumber) {
var orderId = document.getElementById("orderId");
orderId.value = orderNumber;
document.forms["form1"].submit();
}
</script>
<body>
<form action="edit-form.php" id="form1">
<div class="container">
<!--use the hidden input variable to save the order number clicked -->
<input id="orderId" type="hidden" name="orderId"/>
<?php
require("config.php");
$con = new mysqli(DB_Host, DB_User, DB_Password, DB_Name);
if ($con->connect_error) {
die("Connection failed");
}
echo '<table id="tblOrders" name ="OrderTable" style="width: 100%">
<tr>
<th>Sno</th>
<th>Order Number</th>
</tr>';
$displayTableDataQuery = "SELECT id, orderNumber, customerName, deliveryDate FROM orderTable";
if ($tableData = $con-> query($displayTableDataQuery)) {
while($row = $tableData-> fetch_assoc()) {
$id = $row['id'];
$orderNumber = $row["orderNumber"];
echo '<tr >
<td>'.$id.'</td>
<td id = "orderNumber">'.$orderNumber.'</td>
<td><input type = "button" id ="editButton'.$id.'" value = "Edit" onclick = "EditValues('.$orderNumber.');"/> </td>
<td><input type = "button" id = "printInvoice'.$id.'" value="Print" onclick = "PrintInvoice('.$orderNumber.');" /> </td>
</tr>';
}
} else {
echo $con->error;
}
$tableData->free();
?>
</div>
</form>
</body>
在edit-form.php
中<?php
$xyzabc = $_POST['orderId'];
echo $xyzabc;
?>
$ xyzabc没有回应 我希望是否有某种方法可以在没有jQuery的情况下执行此操作,因为我对此还很陌生,并且到目前为止还没有真正了解所有事物如何协同工作。
答案 0 :(得分:0)
您可以将值直接存储到隐藏的输入字段中。
<!--use the hidden input variable to save the order number clicked -->
<input id="orderId" type="hidden" name="orderId" value="<?=$variable_name;?> />
这样,当您提交表单
<?php
$xyzabc = $_POST['orderId'];
echo $xyzabc;
?>
将获取数据。 或者,您可以在url中传递隐藏值。例如
<a href="localhost:8000/edit-form.php?orderId="<?=$variable_name;?>
然后以form-edit.php的形式出现
<?php
$xyzabc = $_GET['orderId'];
echo $xyzabc;
?>