【发布时间】:2017-02-03 13:41:16
【问题描述】:
我正在制作一个测验应用程序,目前有一个遵循以下格式的表格:
| id | question | option1 | option2 | option3 | answer |
--------------------------------------------------------
| 1 | What is my name? | Dave | Bob | Charles | Linda |
我目前有这个代码,它可以正确输出我在表格中的所有信息:
<?php
//Connection code included above
$query="SELECT * FROM MatQuiz";
$result = mysql_query($query, $connect);
?>
<?php
while($row = mysql_fetch_assoc($result)) {
echo $row['id'] . '. ';
echo $row['question'] . '<br><br>';
?>
<input type="radio" name="ID <?php $row['id']; ?>" value="<?php $row['option1']; ?>"><?php echo $row['option1'] ?><br>
<input type="radio" name="ID <?php $row['id']; ?>" value="<?php $row['option2']; ?>"><?php echo $row['option2']; ?><br>
<input type="radio" name="ID <?php $row['id']; ?>" value="<?php $row['option3']; ?>"><?php echo $row['option3']; ?><br>
<input type="radio" name="ID <?php $row['id']; ?>" value="<?php $row['answer']; ?>"><?php echo $row['answer']; ?><br><br>
<?php
}
?>
此代码以正确的顺序输出我在数据库表中的所有问题,并带有相关的单选按钮和答案。
我想做的是改组:
$row['option1'];
$row['option2'];
$row['option3'];
$row['answer'];
我知道我需要使用 Foreach 循环,并将 $row 数组值分配给另一个数组并使用 shuffle() 函数。每当我这样做时,我都会遇到错误并说无效参数。
如何重新组织答案,使它们不会每次都以相同的顺序显示?
【问题讨论】:
-
为什么不能直接使用
$row['option1']之前的$row['option2']呢? -
为每个数据库行创建一个 $Options 数组。将每个行选项和答案添加到 $Options 数组。然后使用 shuffle($Options):php.net/manual/en/function.shuffle.php。然后使用 forloop 来呈现 $Option 值
-
Sunny,因为这样所有选项都会以相同的顺序出现,但首先从选项 2 开始
-
I encounter an error and says invalid argument显示该代码并显示真正的错误。
标签: php arrays foreach shuffle