主頁(yè) > 知識(shí)庫(kù) > 基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷

基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷

熱門(mén)標(biāo)簽:地圖標(biāo)注項(xiàng)目怎么樣 越南河內(nèi)地圖標(biāo)注 ai機(jī)器人電銷資源 云呼外撥網(wǎng)絡(luò)電話系統(tǒng) 超級(jí)大富翁地圖標(biāo)注 個(gè)人怎樣在百度地圖標(biāo)注地名 硅語(yǔ)電話機(jī)器人公司 騰訊地圖標(biāo)注位置能用多久 機(jī)器人電銷騙局揭秘

1.概述

在開(kāi)發(fā)網(wǎng)絡(luò)考試系統(tǒng)時(shí),考試計(jì)時(shí)并自動(dòng)提交試卷是必不可少的功能。由于在答卷過(guò)程中,試卷不能刷新,所以需要使用Ajax實(shí)現(xiàn)無(wú)刷新操作。運(yùn)行本實(shí)例,訪問(wèn)準(zhǔn)備考試頁(yè)面index.jsp,在該頁(yè)面中,單擊“開(kāi)始考試”按鈕,將打開(kāi)新窗口顯示開(kāi)始考試的頁(yè)面,如圖10.1所示,頁(yè)面會(huì)自動(dòng)計(jì)時(shí),當(dāng)考試時(shí)間結(jié)束時(shí),將自動(dòng)提價(jià)試卷。

2.技術(shù)要點(diǎn)

主要是利用Ajax異步提交技術(shù)和Servlet技術(shù)實(shí)現(xiàn)的。顯示在考試頁(yè)面中的計(jì)時(shí)時(shí)間是在Servlet中設(shè)置的,需要通過(guò)Ajax的異步提交不斷的請(qǐng)求Servlet,從而獲得服務(wù)器返回的最新的計(jì)時(shí)時(shí)間的數(shù)據(jù)。為了便于維護(hù)和代碼的重用,可以將Ajax的請(qǐng)求方法封裝到一個(gè)JS文件中,該方法可以作為一個(gè)公共方法,在程序中使用時(shí)可以直接調(diào)用。

3.具體實(shí)現(xiàn)代碼

在JS文件中構(gòu)建XMLHttpRequest對(duì)象以及請(qǐng)求方法,如下代碼所示:

/**
* 構(gòu)建XMLHttpRequest對(duì)象并請(qǐng)求服務(wù)器
* @param reqType:請(qǐng)求類型(GET或POST)
* @param url:服務(wù)器地址
* @param async:是否異步請(qǐng)求
* @param resFun:響應(yīng)的回調(diào)函數(shù)
* @param parameter :請(qǐng)求參數(shù)
* @return :XMLHttpRequest對(duì)象
*/
function httpRequest(reqType,url,async,resFun,parameter){ 
var request = null;
if( window.XMLHttpRequest ){ //非IE瀏覽器,創(chuàng)建XMLHttpRequest對(duì)象
request = new XMLHttpRequest();
}else if( window.ActiveXObject ){ //IE瀏覽器,創(chuàng)建XMLHttpRequest對(duì)象
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); //打開(kāi)服務(wù)器連接
//設(shè)置MIME類型
request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
request.onreadystatechange = resFun; //設(shè)置處理響應(yīng)的回調(diào)函數(shù)
parameter = encodeURI(parameter); //將參數(shù)字符串進(jìn)行編碼
request.send(parameter); //發(fā)送請(qǐng)求
}
else{ //以GET方式提交
url = url+"?"+parameter; 
request.open(reqType, url, true); //打開(kāi)服務(wù)器連接
request.onreadystatechange = resFun; //響應(yīng)回調(diào)函數(shù)
request.send(null); //發(fā)送請(qǐng)求
}
}
else{
alert( "該瀏覽器不支持Ajax!" );
} 
return request;
} 

(1)新建index.jsp頁(yè),該頁(yè)面是用戶訪問(wèn)的初始頁(yè)。在頁(yè)面中主要包含一個(gè)“開(kāi)始考試”按鈕,該按鈕的onclick事件將調(diào)用打開(kāi)考試窗口的JavaScript函數(shù),關(guān)鍵代碼如下:

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

(2)新建名為StartExam的Servlet實(shí)現(xiàn)類,該類用創(chuàng)建考試的開(kāi)始時(shí)間和剩余時(shí)間。在該類中,創(chuàng)建一個(gè)全局變量examTime,用于記錄考試時(shí)間,該變量的值是在web.xml中設(shè)置的,關(guān)鍵代碼如下:

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類中,編寫(xiě)用于將頁(yè)面轉(zhuǎn)發(fā)到開(kāi)始考試頁(yè)面的方法startExam()。關(guān)鍵代碼如下:

public void startExam(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
HttpSession session = request.getSession();
request.setAttribute("time", examTime); //保存考試時(shí)間
session.setAttribute("startTime1",new Date().getTime()); //保存當(dāng)前時(shí)間的毫秒數(shù)
request.getRequestDispatcher("startExam.jsp").forward(request, response);
} 

(4)新建showStartTime.jsp頁(yè),用于輸出計(jì)時(shí)開(kāi)始時(shí)間。關(guān)鍵代碼如下:

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

(5)新建showRemainTime.jsp頁(yè),用于輸出計(jì)時(shí)剩余時(shí)間。關(guān)鍵代碼如下:

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

(6)新建開(kāi)始考試頁(yè)面startExam.jsp頁(yè),在該頁(yè)中通過(guò)調(diào)用Ajax請(qǐng)求方法請(qǐng)求StartExam類,獲得考試的開(kāi)始時(shí)間和剩余時(shí)間。關(guān)鍵代碼如下:

var request1= false;
var request2 = false;
//請(qǐng)求Servlet獲得開(kāi)始時(shí)間 
function showStartTime(){
var url = "StartExam";
//此處需要加nocache="+new Date().getTime(),否則將出現(xiàn)時(shí)間不自動(dòng)走動(dòng)的情況
var parameter="action=showStartTimenocache="+new Date().getTime();
request1 = httpRequest("post",url,true,callbackFunc,parameter); 
}
//回調(diào)函數(shù) 
function callbackFunc(){
if( request1.readyState==4 ){ 
if( request1.status == 200 ){
showStartTimediv.innerHTML=request1.responseText;
}
}
}
//請(qǐng)求Servlet獲得剩余時(shí)間 
function showRemainTime(){
var url = "StartExam";
var parameter="action=showRemainTimenocache="+new Date().getTime();
request2 = httpRequest("post",url,true,callbackFunc_R,parameter); 
}
//回調(diào)函數(shù) 
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)為了實(shí)現(xiàn)頁(yè)面加載后自動(dòng)計(jì)時(shí),需要在開(kāi)始考試頁(yè)面的 body>標(biāo)簽中通過(guò)onload事件應(yīng)用window.setInterval()方法調(diào)用showStartTime()函數(shù)和showRemailTime()函數(shù),關(guān)鍵代碼如下:

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

以上所述是小編給大家介紹的基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷 的相關(guān)知識(shí),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • jquery ajax的success回調(diào)函數(shù)中實(shí)現(xiàn)按鈕置灰倒計(jì)時(shí)

標(biāo)簽:鄭州 海南 林芝 舟山 內(nèi)蒙古 遼源 邢臺(tái) 洛陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷》,本文關(guān)鍵詞  基于,Ajax,技術(shù),實(shí)現(xiàn),考試,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章