• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    基于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中设置的,关键代码如下:

    servlet>
    servlet-name>StartExam/servlet-name>
    servlet-class>com.lh.servlet.StartExam/servlet-class>
    init-param>
    param-name>examTime/param-name>
    param-value>20/param-value>
    /init-param>
    /servlet> 

    (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页,用于输出计时开始时间。关键代码如下:

    %@page contentType="text/html" pageEncoding="GBK"%>
    ${showStartTime} 

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

    %@page contentType="text/html" pageEncoding="GBK"%>
    ${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=showStartTimenocache="+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=showRemainTimenocache="+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)为了实现页面加载后自动计时,需要在开始考试页面的 body>标签中通过onload事件应用window.setInterval()方法调用showStartTime()函数和showRemailTime()函数,关键代码如下:

    body onLoad="showStartTime();showRemainTime();" onkeydown="keydown()">

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

    您可能感兴趣的文章:
    • jquery ajax的success回调函数中实现按钮置灰倒计时
    上一篇:基于Ajax技术实现文件上传带进度条
    下一篇:Ajax基础详解教程(一)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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