2017-08-30 58 views
0

我有一个单选按钮,它使用一个保存字符串值的foreach循环从数据库中获取并显示。我设置了另一个隐藏的输入以及保存每个数据的ID的单选按钮。获取单选按钮的隐藏输入

$sql = "SELECT DISTINCT(class) FROM program WHERE level = '".$level."' AND title = '".$title."'"; 
$result = $conn->query($sql); 

if ($result->num_rows > 0) { 
    $i = 1; 
    while($row = $result->fetch_assoc()) { 
     echo '<ul>'; 
     echo '<li>'; 
     echo $row['class']; 
     echo '<input type="hidden" value="'.$row['class'].'"'; 
     echo '</li>'; 
     echo '<li>'; 
     echo '<ul><li><input name="timeslot['.$i.']" type="radio" value="" checked>N/A</li></ul>'; 

     $sql2 = 'SELECT * FROM program WHERE class = "'.$row['class'].'"'; 
     $result2 = $conn->query($sql2); 

     if ($result->num_rows > 0) { 
      while($row2 = $result2->fetch_assoc()) { 
       echo '<ul>'; 
       echo '<li>'; 
       echo '<input name="timeslot['.$i.']" type="radio" value="'.$row['class'].', '.$row2['timeslot'].'" />'.$row2['timeslot']; 
       echo '<input type="hidden" name="slot_id['.$i.']" value="'.$row2['id'].'"'; 
       echo '</li>'; 
       echo '</ul>'; 
      } 
     } 

     echo '</li>'; 
     echo '</ul>'; 
     $i++; 
    } 
} 

当提交表单时,我的隐藏值总是得到每个组的最后一行。如何在选中的单选按钮上获取id值?

+0

当建立一个SQL查询时,你应该绑定变量,而不是只是串联一个字符串。你在做什么可能会受到攻击。请参阅https://stackoverflow.com/questions/1860130/how-to-bind-sql-variables-in-php – ivo

回答

0

您并未关闭输入隐藏字段。

此外,我会建议改变这种方式,而不是收音机和隐藏,如果你不需要每个ID在服务器。

echo '<input name="timeslot['.$row2['id'].']" type="radio" value="'.$row['class'].', '.$row2['timeslot'].'" />'.$row2['timeslot'];