选择或不选择单选按钮的不同值

时间:2017-01-14 18:04:10

标签: javascript php jquery radio-button

我正在网上考试网站上工作。

当我想用其选择来定义问题时,我应该选择正确的选择。所以每个选项前面都有一个单选按钮,如果我选择它,那将是正确的选择。

我想当我选择其中一个单选按钮时,它的值将是' 1'如果没有,该值将为' 0',因此我可以使用foreach将它们保存在数据库中。这是我的问题。

由于选项数量不明确(从2到更多)并且可以动态添加,我无法为它们设置特定值。

我使用了isset和foreach,但我想我没有以正确的方式使用它们。 我认为可以通过javascript或jquery完成,但我不知道如何。

choice 1:
<textarea class="form-control" name="choice[]" placeholder="choice text"></textarea>
<label><input type="radio" name="correct[]">Correct</label>

choice 2:
<textarea class="form-control" name="choice[]" placeholder="choice text"></textarea>
<label><input type="radio" name="correct[]">Correct</label>

Other Choices ...



<?php
foreach ( $_POST['choice'] as $key => $value ){
if (!empty($value)){
    foreach ($_POST['correct'] as $value2){ 
    if (isset($value2)) $choice_answer = '1'; else $choice_answer = '0';}

mysqli_query($server,"INSERT INTO question_choices (question_id,exam_id,choice,answer) VALUES ('$question_id','$current_exam_id','$value','$choice_answer')");}}
?>

1 个答案:

答案 0 :(得分:0)

所以你把你的选择存储在一个数组中,这很好。但是,您还可以将正确的指示符存储在数组中。你不需要在数组中,因为只有一个正确的选择。

因此,请将correct[]更改为correct,并为每个选项逐步设置值。

例如:

choice 1:
<textarea class="form-control" name="choice[]" placeholder="choice text"></textarea>
<label><input type="radio" name="correct" value=0>Correct</label>

choice 2:
<textarea class="form-control" name="choice[]" placeholder="choice text"></textarea>
<label><input type="radio" name="correct" value=1>Correct</label>

choice 3:
<textarea class="form-control" name="choice[]" placeholder="choice text"></textarea>
<label><input type="radio" name="correct" value=2>Correct</label>

由于只发布了选定的单选按钮,$_POST['correct']将包含$_POST['choice']数组中正确答案的索引。

然后,您可以执行以下操作,在发送到数据库之前相应地设置值:

foreach ($_POST['choice'] as $i => $choice) {
    if (!empty($choice)) {

        if($_POST['correct'] == $i){
            $choice_answer = 1;
        } else {
            $choice_answer = 0;
        }

        mysqli_query($server, "INSERT INTO question_choices (question_id,exam_id,choice,answer) VALUES ('$question_id','$current_exam_id','$value','$choice_answer')");
    }
}