PHP+MySQL实现在线测试答题实例
这个实例主要给大家介绍如何使用jQuery+PHP+MySQL来实现在线测试题,包括动态读取题目,答题完毕后台评分,并返回答题结果。
读取答题列表:
$sql="select*fromquizorderbyidasc"; $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);
生成答题列表:
通过遍历出来的列表,生成答题功能:
$(function(){ $('#quiz-container').jquizzy({ questions:,//试题信息 sendResultsURL:'data.php'//结果处理地址 }); });
当用户打完题,点击“完成”按钮时,会向ajax.php发送一个Ajax交互请求,ajax.php会根据用户的答题情况,比对正确答案,然后给出用户所得分。
$data=$_REQUEST['an']; $answers=explode('|',$data); $an_len=count($answers)-1;//题目数 $sql="selectcorrectfromquizorderbyidasc"; $query=mysql_query($sql); $i=0; $score=0;//初始得分 $q_right=0;//答对的题数 while($row=mysql_fetch_array($query)){ if($answers[$i]==$row['correct']){ $arr['res'][]=1; $q_right+=1; }else{ $arr['res'][]=0; } $i++; } $arr['score']=round(($q_right/$an_len)*100);//总得分 echojson_encode($arr);
quiz表结构:
CREATETABLEIFNOTEXISTS`quiz`( `id`int(11)NOTNULLAUTO_INCREMENT, `question`varchar(100)NOTNULL, `answer`varchar(500)NOTNULL, `correct`tinyint(2)NOTNULL, PRIMARYKEY(`id`) )ENGINE=MyISAMDEFAULTCHARSET=utf8AUTO_INCREMENT=6; -- --转存表中的数据`quiz` -- INSERTINTO`quiz`(`id`,`question`,`answer`,`correct`)VALUES (1,'罗马帝国曾一度辉煌,令人神往,故有“条条大陆通罗马”一说。那么,今天你是怎样理解这一谚语的准确含义的?','A.入乡随俗###B.四通八达###C.殊途同归###D.流连忘返',3), (2,'找出不同类的一项:','A.斑马###B.军马###C.赛马###D.骏马###E.驸马',5), (3,'蜡烛在空气中燃烧,蜡烛质量逐渐变小。这说明','A.物质可以自生自灭###B.发生的不是化学变化###C.不遵守质量守恒定律###D.生成物为气体,散发到空气中了',4), (4,'以下哪位歌手没有获得过《我是歌手》总冠军?','A.羽泉###B.韩磊###C.邓紫棋###D.韩红',3), (5,'下列哪个标签不是HTML5中的新标签?','A.###B.
总结
以上所述是小编给大家介绍的PHP+MySQL实现在线测试答题实例,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。