类似提交试卷的ajax,基于Ajax技术实现考试倒计时并自动提交试卷

1.概述

在开发网络考试系统时,考试计时并自动提交试卷是必不可少的功能。由于在答卷过程中,试卷不能刷新,所以需要使用Ajax实现无刷新操作。运行本实例,访问准备考试页面index.jsp,在该页面中,单击“开始考试”按钮,将打开新窗口显示开始考试的页面,如图10.1所示,页面会自动计时,当考试时间结束时,将自动提价试卷。

2.技术要点

主要是利用Ajax异步提交技术和Servlet技术实现的。显示在考试页面中的计时时间是在Servlet中设置的,需要通过Ajax的异步提交不断的请求Servlet,从而获得服务器返回的最新的计时时间的数据。为了便于维护和代码的重用,可以将Ajax的请求方法封装到一个JS文件中,该方法可以作为一个公共方法,在程序中使用时可以直接调用。

3.具体实现代码

在JS文件中构建XMLHttpRequest对象以及请求方法,如下代码所示:

/**

* 构建XMLHttpRequest对象并请求服务器

* @param reqType:请求类型(GET或POST)

* @param url:服务器地址

* @param async:是否异步请求

* @param resFun:响应的回调函数

* @param parameter :请求参数

* @return :XMLHttpRequest对象

*/

function httpRequest(reqType,url,async,resFun,parameter){

var request = null;

if( window.XMLHttpRequest ){ //非IE浏览器,创建XMLHttpRequest对象

request = new XMLHttpRequest();

}else if( window.ActiveXObject ){ //IE浏览器,创建XMLHttpRequest对象

var arrSignatures = ["Msxml2.XMLHTTP", "Microsoft.XMLHTTP", "Microsoft.XMLHTTP", "MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0", "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP"];

for( var i = 0; i < arrSignatures.length; i++ ){

request = new ActiveXObject( arrSignatures[i] );

if( request || typeof( request ) == "object" )

break;

}

}

if( request || typeof( request ) == "object" ){

if(reqType.toLowerCase()=="post"){ //以POST方式提交

request.open(reqType, url, true); //打开服务器连接

//设置MIME类型

request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

request.onreadystatechange = resFun; //设置处理响应的回调函数

parameter = encodeURI(parameter); //将参数字符串进行编码

request.send(parameter); //发送请求

}

else{ //以GET方式提交

url = url+"?"+parameter;

request.open(reqType, url, true); //打开服务器连接

request.onreadystatechange = resFun; //响应回调函数

request.send(null); //发送请求

}

}

else{

alert( "该浏览器不支持Ajax!" );

}

return request;

}

(1)新建index.jsp页,该页面是用户访问的初始页。在页面中主要包含一个“开始考试”按钮,该按钮的onclick事件将调用打开考试窗口的JavaScript函数,关键代码如下:

function showWindow(){ window.open('StartExam?action=startExam','','width=750,height=500,scrollbars=1');

}

(2)新建名为StartExam的Servlet实现类,该类用创建考试的开始时间和剩余时间。在该类中,创建一个全局变量examTime,用于记录考试时间,该变量的值是在web.xml中设置的,关键代码如下:

StartExam

com.lh.servlet.StartExam

examTime

20

(3)在StartExam类中,编写用于将页面转发到开始考试页面的方法startExam()。关键代码如下:

public void startExam(HttpServletRequest request,HttpServletResponse response)

throws ServletException,IOException{

HttpSession session = request.getSession();

request.setAttribute("time", examTime); //保存考试时间

session.setAttribute("startTime1",new Date().getTime()); //保存当前时间的毫秒数

request.getRequestDispatcher("startExam.jsp").forward(request, response);

}

(4)新建showStartTime.jsp页,用于输出计时开始时间。关键代码如下:

${showStartTime}

(5)新建showRemainTime.jsp页,用于输出计时剩余时间。关键代码如下:

${showRemainTime}

(6)新建开始考试页面startExam.jsp页,在该页中通过调用Ajax请求方法请求StartExam类,获得考试的开始时间和剩余时间。关键代码如下:

var request1= false;

var request2 = false;

//请求Servlet获得开始时间

function showStartTime(){

var url = "StartExam";

//此处需要加&nocache="+new Date().getTime(),否则将出现时间不自动走动的情况

var parameter="action=showStartTime&nocache="+new Date().getTime();

request1 = httpRequest("post",url,true,callbackFunc,parameter);

}

//回调函数

function callbackFunc(){

if( request1.readyState==4 ){

if( request1.status == 200 ){

showStartTimediv.innerHTML=request1.responseText;

}

}

}

//请求Servlet获得剩余时间

function showRemainTime(){

var url = "StartExam";

var parameter="action=showRemainTime&nocache="+new Date().getTime();

request2 = httpRequest("post",url,true,callbackFunc_R,parameter);

}

//回调函数

function callbackFunc_R(){

if( request2.readyState==4 ){

if( request2.status == 200 ){

h=request2.responseText;

showRemainTimediv.innerHTML=h;

h=h.replace(/\s/g,""); //去除字符串中的Unicode空白符

showRemainTimediv.innerHTML=h;

if(h=="00:00:00"){

form1.submit();

}

}

}

}

(7)为了实现页面加载后自动计时,需要在开始考试页面的

标签中通过onload事件应用window.setInterval()方法调用showStartTime()函数和showRemailTime()函数,关键代码如下:

以上所述是小编给大家介绍的基于Ajax技术实现考试倒计时并自动提交试卷 的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持! ad51e517755f8fd6a7ec83ced4ecfaf3.png

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值