Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/378.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在php中将选中的单选按钮值保留到下一页?_Php_Javascript_Jquery - Fatal编程技术网

如何在php中将选中的单选按钮值保留到下一页?

如何在php中将选中的单选按钮值保留到下一页?,php,javascript,jquery,Php,Javascript,Jquery,我正在做一个在线测验应用程序,当我单击下一个按钮时,我需要将所有选定的单选按钮值保留到下一页,因为我使用分页。在下面的代码中,当我移动到下一页时,它会显示未定义的偏移量错误。我在此行/>中又遇到了一个语法错误,如“意外检查”。$optA[$I]。' 我需要解决这些问题,请帮助任何人,提前感谢 <?php session_start(); include('connection.php'); mysql_select_db('quiz_apptitude');

我正在做一个在线测验应用程序,当我单击下一个按钮时,我需要将所有选定的单选按钮值保留到下一页,因为我使用分页。在下面的代码中,当我移动到下一页时,它会显示未定义的偏移量错误。我在此行/>中又遇到了一个语法错误,如“意外检查”。$optA[$I]。' 我需要解决这些问题,请帮助任何人,提前感谢

 <?php
    session_start();
    include('connection.php');
    mysql_select_db('quiz_apptitude');
    $sql = mysql_query("SELECT * FROM prob_on_age");
    $nr = mysql_num_rows($sql); 
    if (isset($_GET['pn'])) {
        $pn = preg_replace('#[^0-9]#i', '', $_GET['pn']); 
    } else { 
        $pn = 1;
    } 

    $itemsPerPage = 2; 

    $lastPage = ceil($nr / $itemsPerPage);

    if ($pn < 1) {
        $pn = 1; 
    } else if ($pn > $lastPage) { 
        $pn = $lastPage; 
    } 

    $centerPages = "";
    $sub1 = $pn - 1;
    $sub2 = $pn - 2;
    $add1 = $pn + 1;
    $add2 = $pn + 2;
    if ($pn == 1) {
        $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add1 . '">' . $add1 . '</a> &nbsp;';
    } else if ($pn == $lastPage) {
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub1 . '">' . $sub1 . '</a> &nbsp;';
        $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
    } else if ($pn > 2 && $pn < ($lastPage - 1)) {
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub2 . '">' . $sub2 . '</a> &nbsp;';
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub1 . '">' . $sub1 . '</a> &nbsp;';
        $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add1 . '">' . $add1 . '</a> &nbsp;';
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add2 . '">' . $add2 . '</a> &nbsp;';
    } else if ($pn > 1 && $pn < $lastPage) {
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub1 . '">' . $sub1 . '</a> &nbsp;';
        $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
        $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add1 . '">' . $add1 . '</a> &nbsp;';
    }

    $limit = 'LIMIT ' .($pn - 1) * $itemsPerPage .',' .$itemsPerPage; 

    $sql2 = mysql_query("SELECT * FROM prob_on_age $limit") or die('error'); 
    //$total=mysql_num_rows($sql2) ;
    $i=0;
    $outputList = '';
    while($row = mysql_fetch_array($sql2)){ 

       $Question[]=$row['prob_Question'];
    $optA[]=$row['prob_OptionA'];
    $optB[]=$row['prob_OptionB'];
    $optC[]=$row['prob_OptionC'];
    $optD[]=$row['prob_OptionD'];
    $ans[]=$row['prob_Answer'];
    $Qid[$i]=$row['prob_Qid'];

        $ans[$i]=$row['prob_Answer'];
                         $r=$i+1;




        $outputList .= '<table><tr>
                  <td> '.$r.' . '.$Question[$i].'</td>
                </tr>
                <tr>  <td><input type="hidden" name="'.$Qid[$i].'" id="'.$Qid[$i].'" value="'.$Qid[$i].'" /></td>
                </tr>
                  <tr>

                  <td><input type="radio"  name=" '.$Qid[$i].'" id="'.$Qid[$i].'"  value="'.$optA[$i].'" <?php echo '.$optA[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/> 
                    '.$optA[$i].'</td></tr>
                    <tr> <td><input type="radio" name=" '.$Qid[$i].'" id="'.$Qid[$i].'" value="'.$optB[$i].'" <?php echo '.$optB[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?> />
                    '.$optB[$i].'</td></tr>
                 <tr> <td><input type="radio" name=" '.$Qid[$i].'"  id="'.$Qid[$i].'" value="'.$optC[$i].'"  <?php echo '.$optC[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/>
                   '.$optC[$i].'</td></tr>
                <tr>  <td><input type="radio" name=" '.$Qid[$i].'" id="'.$Qid[$i].'"  value="'.$optD[$i].'"  <?php echo '.$optD[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/>
                '.$optD[$i].'</td></tr>

                <tr>  <td><input type="hidden" name="'.$ans[$i].'" id="'.$Qid[$i].'"  value="'.$ans[$i].'" /></td>
                </tr></table>';

    $i++;
    }

    $count=count($Qid);
    $paginationDisplay = ""; 
    if ($lastPage != "1"){

        $paginationDisplay .= 'Page <strong>' . $pn . '</strong> of ' . $lastPage. '&nbsp;  &nbsp;  &nbsp; ';

        if ($pn != 1) {
            $previous = $pn - 1;

            $paginationDisplay .=  '&nbsp;  <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $previous . '"> Back</a> ';
        } 

        $paginationDisplay .= '<span class="paginationNumbers">' . $centerPages . '</span>';

        if ($pn != $lastPage) {
            $nextPage = $pn + 1;

            $paginationDisplay .=  '&nbsp;  <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $nextPage . '">Next</a> ';
        } 
    }

    ?>

<?php
session_start();


include('connection.php');
mysql_select_db('quiz_apptitude');
$sql = mysql_query("SELECT * FROM prob_on_age");
$nr = mysql_num_rows($sql); 
if (isset($_GET['pn'])) {
    $pn = preg_replace('#[^0-9]#i', '', $_GET['pn']); 
} else { 
    $pn = 1;
} 

$itemsPerPage = 2; 

$lastPage = ceil($nr / $itemsPerPage);

if ($pn < 1) {
    $pn = 1; 
} else if ($pn > $lastPage) { 
    $pn = $lastPage; 
} 

$centerPages = "";
$sub1 = $pn - 1;
$sub2 = $pn - 2;
$add1 = $pn + 1;
$add2 = $pn + 2;
if ($pn == 1) {
    $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add1 . '">' . $add1 . '</a> &nbsp;';
} else if ($pn == $lastPage) {
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub1 . '">' . $sub1 . '</a> &nbsp;';
    $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
} else if ($pn > 2 && $pn < ($lastPage - 1)) {
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub2 . '">' . $sub2 . '</a> &nbsp;';
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub1 . '">' . $sub1 . '</a> &nbsp;';
    $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add1 . '">' . $add1 . '</a> &nbsp;';
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add2 . '">' . $add2 . '</a> &nbsp;';
} else if ($pn > 1 && $pn < $lastPage) {
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $sub1 . '">' . $sub1 . '</a> &nbsp;';
    $centerPages .= '&nbsp; <span class="pagNumActive">' . $pn . '</span> &nbsp;';
    $centerPages .= '&nbsp; <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $add1 . '">' . $add1 . '</a> &nbsp;';
}

$limit = 'LIMIT ' .($pn - 1) * $itemsPerPage .',' .$itemsPerPage; 

$sql2 = mysql_query("SELECT * FROM prob_on_age $limit") or die('error'); 
//$total=mysql_num_rows($sql2) ;
$i=0;
$outputList = '';
while($row = mysql_fetch_array($sql2)){ 

   $Question[]=$row['prob_Question'];
$optA[]=$row['prob_OptionA'];
$optB[]=$row['prob_OptionB'];
$optC[]=$row['prob_OptionC'];
$optD[]=$row['prob_OptionD'];
$ans[]=$row['prob_Answer'];
$Qid[$i]=$row['prob_Qid'];

    $ans[$i]=$row['prob_Answer'];
                     $r=$i+1;




    $outputList .= '<table><tr>
              <td> '.$r.' . '.$Question[$i].'</td>
            </tr>
            <tr>  <td><input type="hidden" name="'.$Qid[$i].'" id="'.$Qid[$i].'" value="'.$Qid[$i].'" /></td>
            </tr>
              <tr>

              <td><input type="radio"  name=" '.$Qid[$i].'" id="'.$Qid[$i].'"  value="'.$optA[$i].'" <?php echo '.$optA[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/> 
                '.$optA[$i].'</td></tr>
                <tr> <td><input type="radio" name=" '.$Qid[$i].'" id="'.$Qid[$i].'" value="'.$optB[$i].'" <?php echo '.$optB[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?> />
                '.$optB[$i].'</td></tr>
             <tr> <td><input type="radio" name=" '.$Qid[$i].'"  id="'.$Qid[$i].'" value="'.$optC[$i].'"  <?php echo '.$optC[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/>
               '.$optC[$i].'</td></tr>
            <tr>  <td><input type="radio" name=" '.$Qid[$i].'" id="'.$Qid[$i].'"  value="'.$optD[$i].'"  <?php echo '.$optD[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/>
            '.$optD[$i].'</td></tr>

            <tr>  <td><input type="hidden" name="'.$ans[$i].'" id="'.$Qid[$i].'"  value="'.$ans[$i].'" /></td>
            </tr></table>';

$i++;


}

$count=count($Qid);








$paginationDisplay = ""; 
if ($lastPage != "1"){

    $paginationDisplay .= 'Page <strong>' . $pn . '</strong> of ' . $lastPage. '&nbsp;  &nbsp;  &nbsp; ';

    if ($pn != 1) {
        $previous = $pn - 1;

        $paginationDisplay .=  '&nbsp;  <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $previous . '"> Back</a> ';
    } 

    $paginationDisplay .= '<span class="paginationNumbers">' . $centerPages . '</span>';

    if ($pn != $lastPage) {
        $nextPage = $pn + 1;

        $paginationDisplay .=  '&nbsp;  <a href="' . $_SERVER['PHP_SELF'] . '?pn=' . $nextPage . '">Next</a> ';
    } 
}

?>

    <html>
    <head>
    <title>online QiuZ</title>
    </head>
    <body>
       <div style="margin-left:64px; margin-right:64px;">
         <h2>Problem On Age</h2>
       </div> 
       <!--   <div style="margin-left:58px; margin-right:58px; padding:6px; background-color:#FFF; border:#999 1px solid;"><?php //echo $paginationDisplay; ?></div>-->
          <div style="margin-left:64px; margin-right:64px;">
          <form name="prob_age" id="prob_age" method="post" action="result-age.php" >
          <?php print "$outputList"; ?>

          <div style="margin-left:58px; margin-right:58px; padding:6px; background-color:#FFF; border:#999 1px solid;"><?php echo $paginationDisplay; ?></div>
          <input type="submit" name="submit" id="submit" value="submit">

          </form>
          </div>

    </body>
    </html>

检查代码后,我发现变量$output list数据不正确。替换为以下内容:

$output .= ....//other code
$output .= ($optB[$i] == $_POST[$Qid[$i]]) ? ' checked="checked"' : '';
$output .= ......
您在php变量的字符串中回显if条件:

<?php echo '.$optB[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : '';

替换你的每一个代码> p>好,你可以用<代码> PHP会话和/或<代码> Cookie >(几乎与你的情况相同),但是如果出于任何原因,在测验的中间出现了一些错误。您将丢失所有进度,用户必须重新开始

如果测验很短,你可以这样做,但如果测验>=中长测验。。。我建议使用
$\u POST
&
表单
,而不是分页链接。当然,同时也要保存进度

有了这个,如果你想预先检查单选按钮,输入字段,或任何东西。。。下次打开该页面时只需调用适当的变量(也可能是另一天,因为这些值存储在服务器中,而不是用户计算机中。)

祝你好运

cookie
就是你想要的艺术:对不起。。。我找不到你,请简要解释“$optA[$i]”。我像上面那样编辑,再次检查语法错误未定义。如果我错了,请解释again@user1877928不是说用它<代码>“.$optA[$i]”...
很抱歉,我找不到你,我将使用会话或cookie,每页使用20个问题。你依赖用户计算机,让他有机会继续已经开始的测验。如果您使用
Form&post
并在每页中保存数据,则用户可以随时在任何计算机上继续。当然,您可以使用
PHP var
预加载信息,包括单选按钮。我无法为您获取信息。请简要解释您不了解的内容?您上面写的
PHP
代码是您的还是从某处复制的?
$outputList .='<table><tr>
              <td> '.$r.' . '.$Question[$i].'</td>
               </tr>
               <tr>  <td><input type="hidden" name="'.$Qid[$i].'" id="'.$Qid[$i].'" value="'.$Qid[$i].'" /></td>
            </tr>
              <tr>

              <td><input type="radio"  name=" '.$Qid[$i].'" id="'.$Qid[$i].'"  value="'.$optA[$i].'" 

<?php echo '.$optA[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>
/> 
                '.$optA[$i].'</td></tr>
                <tr> <td><input type="radio" name=" '.$Qid[$i].'" id="'.$Qid[$i].'" value="'.$optB[$i].'" <?php echo '.$optB[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?> />
                '.$optB[$i].'</td></tr>
             <tr> <td><input type="radio" name=" '.$Qid[$i].'"  id="'.$Qid[$i].'" value="'.$optC[$i].'"  <?php echo '.$optC[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/>
               '.$optC[$i].'</td></tr>
            <tr>  <td><input type="radio" name=" '.$Qid[$i].'" id="'.$Qid[$i].'"  value="'.$optD[$i].'"  <?php echo '.$optD[$i].' == $_POST[''.$Qid[$i].''] ? ' checked="checked"' : ''; ?>/>
            '.$optD[$i].'</td></tr>

            <tr>  <td><input type="hidden" name="'.$ans[$i].'" id="'.$Qid[$i].'"  value="'.$ans[$i].'" /></td>
            </tr></table>';