php - 在 html 表中使用单选按钮?

标签 php html mysql radio-button

相当菜鸟的问题,但我已经尝试搜索但找不到解决方案。我的问题是我有一个名为 Off 的表,它存储了所有员工的假期。但是,工作人员在那天休假之前必须获得授权。我有一个获取所有未经授权的假期的查询,并将它们显示在 html 表中。问题是每条记录需要 2 个单选按钮。一种用于授权,一种用于拒绝。会显示单选按钮,但在浏览记录时只能选择其中一个单选按钮。是否可以这样使用单选按钮?

<?php 
$path = $_SERVER['DOCUMENT_ROOT'];
$path .= "/Apollo/dbc.php";
include_once($path);



$rs_results = mysql_query("SELECT * FROM off WHERE IsItAuthorised='0' and isitsick='0' ORDER BY DayOff");

?>
<html>
<head>
<title>Administration Main Page</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<?php


    $limit = count($OffID);

if (isset($_POST['submit'])) {
    //Assign each array to a variable
    $id = $_POST['OffID'];
    $answer = $_POST['radio'];



    $limit = count($OffID);




$values = array(); // initialize an empty array to hold the values
    for($k=0;$k<$limit;$k++){
    $msg[] = "$limit New KPI's Added";


          $query = "UPDATE Off SET IsItAuthorised = '{$answer[$k]}' WHERE OffID = '{$OffID[$k]}'";
    }



    $Event = "INSERT INTO events (UserName, Event ) VALUES ('$_SESSION[user_name]', 'Entered New KPI' )";   



if (!mysql_query($query,$link)){
        die('Error: ' . mysql_error());
    } else {

        mysql_query($Event);
        echo "<div class=\"msg\">" . $msg[0] . "</div>";
    }




}                             
?>


</head>

<body>
<table width="100%" border="0" cellspacing="0" cellpadding="0">
  <tr>
    <td width="14%" valign="top"><?php

?>

    </td>
    <td width="74%" valign="top" style="padding: 10px;">

      <p><?php 
      if(!empty($msg)) {
      echo $msg[0];
      }
      ?></p>

      <p>
        <?php 
      $cond = '';






      $sql = "select * from off ";



      $rs_total = mysql_query($sql) or die(mysql_error());
      $total = mysql_num_rows($rs_total);


      ?>

      <p>

        <form name "searchform" action="/Apollo/Admin/HolidayRequests" method="post">
        <table width="100%" border="0" align="center" cellpadding="2" cellspacing="0">
          <tr class="mytables"> 
            <td width="4%"><font color="white"><strong>ID</font></strong></td>
            <td width="4%"> <font color="white"><strong>Staff Member</font></strong></td>
            <td width="10%"><font color="white"><strong>Day Off</font></strong></div></td>
             <td width="10%"><font color="white"><strong>Is It Authorized</font></strong></div></td>
            <td width="15%">&nbsp;</td>
          </tr>


          <tr> 
            <td>&nbsp;</td>
            <td width="10%">&nbsp;</td>
            <td width="17%"><div align="center"></div></td>
            <td>&nbsp;</td>
          </tr>
          <?php while ($rrows = mysql_fetch_array($rs_results)) {?>
          <tr> 
            <td><input type="" name="id[]" id="id[]" size="4" value="<?php echo $rrows['OffID'];?>" /></td>
            <td><?php echo $rrows['StaffMember']; ?></td>
            <td><?php echo date('d/m/Y', strtotime($rrows['DayOff']));?></div></td>

            <td> <span id="approve<?php echo $rrows['id']; ?>"> 
              <?php if(!$rrows['IsItAuthorised']) { echo "Pending"; } else {echo "Authorized"; }?>
              </span> </td>

              <td>


                    <input type="radio" name="radio[0]"  id="radio[0]" value="1" />Approve
                        <input type="radio" name="radio[1]"  id="radio[1]"  value="0" />Deny



         </td>
          </tr>

          <?php } ?>
        </table>
          <input name="submit" type="submit" id="submit" value="Submit">
      </form>


      &nbsp;</p>
      <?php


      ?>


      <p>&nbsp;</p>
      <p>&nbsp;</p>
      <p>&nbsp;</p>
      <p>&nbsp;</p></td>
    <td width="12%">&nbsp;</td>
  </tr>
</table>
</body>
</html>

最佳答案

您的问题与您对“名称”属性的使用有关 - 此属性以特殊方式用于单选按钮。

当你点击一个单选按钮时,所有其他同名的单选按钮都被取消选择 - 在你的情况下,你将在页面上有一半的单选按钮在一组中,另一半在另一组中,这可能会解释为什么你只能选择一个。我想如果您单击正确的单选按钮,您实际上可以同时选择两个。

要解决此问题,您需要对 while 循环进行某种计数,即:

$resultNumber = 0;
while ($rrows = mysql_fetch_array($rs_results)) {

然后你需要在单选按钮的名称(以及 id)中使用这个数字 -

<input type="radio" name="radio<?php echo $resultNumber; ?>"  id="radio<?php echo $resultNumber; ?>" value="1" />

然后在每次迭代结束时简单地增加 $resultNumber -

<?php 
    $resultNumber++;
} 
?>

或者,您可以使用您正在查询的数据库表中行的主键来区分组,但不知道表结构我无法为此提供示例代码。

进一步阅读单选按钮(也是 name 属性问题的来源): http://www.echoecho.com/htmlforms10.htm

关于php - 在 html 表中使用单选按钮?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9093405/

相关文章:

javascript - 如何将div用作网格?

Php UPDATE 行函数

php - 字段列表中的列 'nid' 是 Drupal6 中的不明确查询

php - 在查询前更改自动提交并在查询后重置它

php - Laravel 在 Web 服务器的 View 中显示数据

PHP MYSQL FPDF 检索存储为 blob 的 pdf 字符串

php - 运费总额和即时更新 API 的 PayPal 错误

jquery - IOS中的滚动问题

html - Razor 页面创建输入类型日期变成类型文本

mysql - 如何从 linux 文件中删除特定符号?