Beispiel einer Online-Testbeantwortung mit PHP+MySQL

coldplay.xixi
Freigeben: 2023-04-09 14:30:01
nach vorne
3041 Leute haben es durchsucht

?? Das Beispiel ist hauptsächlich Ich möchte es Ihnen vorstellen wie man mit jQuery + PHP + MySQL Online-Testfragen implementiert, einschließlich dynamischem Lesen von Fragen, Hintergrundbewertung nach Beantwortung von Fragen und Rückgabe von Antwortergebnissen.

Beispiel einer Online-Testbeantwortung mit PHP+MySQL

Lesen Sie die Antwortliste:

$sql = "select * from quiz order by id asc"; 
$query = mysql_query($sql); 
while ($row = mysql_fetch_array($query)) { 
 $answers = explode('###', $row['answer']); 
 $arr[] = array( 
   'question' => $row['id'] . '、' . $row['question'], 
   'answers' => $answers 
 ); 
} 
$json = json_encode($arr);
Nach dem Login kopieren
Generieren Sie die Antwortliste:Generieren Sie durch Durchlaufen der Liste die Antwortfunktion:
$(function(){ 
  $('#quiz-container').jquizzy({ 
    questions: <?php echo $json;?>, //试题信息 
    sendResultsURL: &#39;data.php&#39; //结果处理地址 
  }); 
});
Nach dem Login kopieren
Wenn der Benutzer mit der Eingabe der Frage fertig ist und auf die Schaltfläche „Fertig stellen“ klickt , wird eine Nachricht angezeigt, an die ajax.php eine interaktive Ajax-Anfrage sendet. Ajax.php vergleicht die richtige Antwort basierend auf der Antwort des Benutzers und gibt dann die Punktzahl des Benutzers an.
$data = $_REQUEST[&#39;an&#39;]; 

$answers = explode(&#39;|&#39;,$data); 
$an_len = count($answers)-1; //题目数 

$sql = "select correct from quiz order by id asc"; 

$query = mysql_query($sql); 
$i = 0; 
$score = 0; //初始得分 
$q_right = 0; //答对的题数 
while($row=mysql_fetch_array($query)){ 
  if($answers[$i]==$row[&#39;correct&#39;]){ 
    $arr[&#39;res&#39;][] = 1; 
    $q_right += 1; 
  }else{ 
    $arr[&#39;res&#39;][] = 0; 
  } 
  $i++; 
} 
$arr[&#39;score&#39;] = round(($q_right/$an_len)*100); //总得分 
echo json_encode($arr);
Nach dem Login kopieren
Aufbau der Quiztabelle:
CREATE TABLE IF NOT EXISTS `quiz` ( 
 `id` int(11) NOT NULL AUTO_INCREMENT, 
 `question` varchar(100) NOT NULL, 
 `answer` varchar(500) NOT NULL, 
 `correct` tinyint(2) NOT NULL, 
 PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=6 ; 
 
-- 
-- 转存表中的数据 `quiz` 
-- 
 
INSERT INTO `quiz` (`id`, `question`, `answer`, `correct`) VALUES 
(1, &#39;罗马帝国曾一度辉煌,令人神往,故有“条条大陆通罗马”一说。那么,今天你是怎样理解这一谚语的准确含义的?&#39;, &#39;A.入乡随俗 ###B.四通八达 ###C.殊途同归 ###D.流连忘返&#39;, 3), 
(2, &#39;找出不同类的一项:&#39;, &#39;A.斑马 ###B.军马 ###C.赛马 ###D.骏马 ###E.驸马&#39;, 5), 
(3, &#39; 蜡烛在空气中燃烧,蜡烛质量逐渐变小。这说明&#39;, &#39;A.物质可以自生自灭###B.发生的不是化学变化###C.不遵守质量守恒定律###D.生成物为气体,散发到空气中了&#39;, 4), 
(4, &#39;以下哪位歌手没有获得过《我是歌手》总冠军?&#39;, &#39;A.羽泉###B.韩磊###C.邓紫棋###D.韩红&#39;, 3), 
(5, &#39;下列哪个标签不是HTML5中的新标签?&#39;, &#39;A.<article>###B.<canvas>###C.<section>###D.<sub>&#39;, 4);
Nach dem Login kopieren
Wenn Sie mehr über verwandte Lerninhalte erfahren möchten, achten Sie bitte auf die Spalte „PHP-Schulung“!

Das obige ist der detaillierte Inhalt vonBeispiel einer Online-Testbeantwortung mit PHP+MySQL. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:jb51.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage