1

如果您有 abcd 答案或 ab 答案,如何使用此代码使其仅回显收音机或复选框。在我的测验中,它会是 abcd 和 a (true) b (false) 答案。要完成我的测验,这是唯一阻止我完成它的事情。我的问题可能不是重点,但我试图让它接近我所做的事情。谢谢你的帮助。

<?php
    //retreive questions from database and put into question box

    $query2 = "SELECT `QuestionId`, `Question`, `Opt1`, `Opt2`, `Opt3`, `Opt4`,`Answer` FROM `pf_questions`";

    $question2 = mysql_query($query2);

    while($row = mysql_fetch_array($question2)){

        $id         = $row['QuestionId'];
        $question   = $row['Question'];
        $opt1       = $row['Opt1'];
        $opt2       = $row['Opt2'];
        $opt3       = $row['Opt3'];
        $opt4       = $row['Opt4'];
        $answer     = $row["Answer"];




    ?>
    <div id="ContainerQuestion">
        <span class="Question">Question <?php echo $id; ?>. <?php echo $question; ?></span>

            <p><input type=radio name='q<?php echo $id; ?>' <?=( $answer  == 'a')?("checked='checked'"):(""); ?>  value="a"> <?php echo $opt1; ?> </p>
            <p><input type=radio name='q<?php echo $id; ?>' <?=( $answer  == 'b')?("checked='checked'"):(""); ?> value="b"> <?php echo $opt2; ?> </p>
            <p><input type=radio name='q<?php echo $id; ?>' <?=( $answer  == 'c')?("checked='checked'"):(""); ?> value="c"> <?php echo $opt3; ?> </p>

            <p><input type=radio name='q<?php echo $id; ?>' <?=( $answer  == 'd')?("checked='checked'"):(""); ?> value="d"> <?php echo $opt4; ?> </p>


    </div>
    <?php
    }

    ?>
4

2 回答 2

0

我想我明白你在问什么。您想将每一行包装在“if”子句中。例如:

<?php if( isset ($opt3) ) { ?>

<p><input type=radio name='q<?php echo $id; ?>' <?=( $answer  == 'c')?("checked='checked'"):(""); ?> value="c"> <?php echo $opt3; ?> </p>

<?php } 
      if( isset ($opt4) ) { ?>

<p><input type=radio name='q<?php echo $id; ?>' <?=( $answer  == 'd')?("checked='checked'"):(""); ?> value="d"> <?php echo $opt4; ?> </p>

<?php } ?>

有点丑陋的黑客,但它应该工作,你明白了。

于 2012-10-12T22:19:27.957 回答
0

我可能会用while以下内容(未经测试)替换您的循环:

$answerFields = array('Opt1'=>'a', 'Opt2'=>'b', 'Opt3'=>'c', 'Opt4'=>'d');

while($row = mysql_fetch_array($question2)){
    $id         = $row['QuestionId'];
    $question   = $row['Question'];

    // Print Question
    printf('<div id="ContainerQuestion">');
    printf('<span class="Question">Question %s. %s</span>', $id, $question);

    // Print Answers
    foreach($answerFields as $field=>$ans)
    {
        if(array_key_exists($field, $row) && $row[$field])
        {
            $checked = ($row["Answer"] == $ans) ? 'checked' : '';
            printf('<p><input type="radio" name="%s" %s value="%s">%s</p>', 
                $id, $checked, $ans, $row[$field]);
        }
    }
}

如果未设置数据库中的答案字段(Opt1、Opt 等)或为空字符串,则<p>不应打印包含响应的内容。

此解决方案允许您将应用程序扩展到 3/4 响应已填充且 1/4 为空的情况。printf它还通过使用语句而不是在内联 php 和 html 之间跳转来稍微清理您的代码。

最后,强制性说明指出有关准备好的陈述的重要评论。

于 2012-10-12T22:27:40.363 回答