每当用户单击时,PHP 提交按钮


PHP submit button whenever user clicks

我希望在点击提交后收到多个请求。这意味着在我点击提交并获得结果后,我想再次查询结果并再次点击提交。我不想把自己带回虚无。

 <?php
 error_reporting(0);
 if (!$_POST['submit'])
 {
 <form action="http://localhost/test.php" method="post">
 Type of Leave: 
 <select name="leave">
 <option value=""selected="selected"></option>
 <option VALUE="Medical Leave"> Medical Leave</option>
 <option VALUE="Unpaid Leave"> Unpaid Leave</option> 
 </select>
 <input type="submit" name="submit" value="Check!" />
 </form>
 <?php
 }
 else
 {
 $conn=odbc_connect("employee","","") or die (odbc_errormsg());
 if (!$conn)  
 {
 exit
 ("Connection Failed: " . $conn);
 }
 else
 {
 $choice = $_POST['leave'];
 $sql="SELECT * FROM balance WHERE ID=$username";
 $rs=odbc_exec($conn,$sql);
 ?>
 <?php
 while (odbc_fetch_row($rs))
 {
 $choice=odbc_result($rs,"$choice");
 echo "<tr><td>$choice</td>";
 }
 odbc_close($conn);
 echo "</table>";
 }
 }

目前代码本身查询出我想要的预期输出,但唯一的缺点是它作为输出保留在那里。我的目标是让提交和选择选项留在那里,以便我可以继续输出我想要的结果,谢谢。

最佳用户体验是使用 AJAX 根据下拉列表中选择的内容动态更改结果表。对于更简单的解决方案,您可以尝试将表单向上移动并移出 if/else 循环。首先放置表单,然后在打印表单后,检查if ($_POST['submit'])

在此示例中,我还添加了一个小函数,用于将selected="selected"添加到为此提交选择的任何选项。这很粗糙,但你明白了。

<?php
function matchPost($name,$val) {
if($val == $name)
    echo 'selected="selected"';
}
?>
<form action="http://localhost/test.php" method="post">
 Type of Leave: 
 <select name="leave">
 <option value=""></option>
 <option <?php matchPost('Medical_Leave',$_POST['leave']); ?> VALUE="Medical_Leave"> Medical Leave</option>
 <option <?php matchPost('Unpaid_Leave',$_POST['leave']); ?> VALUE="Unpaid_Leave"> Unpaid Leave</option> 
 </select>
 <input type="submit" name="submit" value="Check!" />
 </form>
<?php
 if ($_POST['submit'])
 {
 $conn=odbc_connect("employee","","") or die (odbc_errormsg());
 if (!$conn)  
 {
 exit
 ("Connection Failed: " . $conn);
 }
 else
 {
 $choice = $_POST['leave'];
 $sql="SELECT * FROM balance WHERE ID=$username";
 $rs=odbc_exec($conn,$sql);
 ?>
 <?php
 while (odbc_fetch_row($rs))
 {
 $choice=odbc_result($rs,"$choice");
 echo "<tr><td>$choice</td>";
 }
 odbc_close($conn);
 echo "</table>";
 }
 }