基于Ajax技術(shù)實(shí)現(xiàn)考試倒計(jì)時(shí)并自動(dòng)提交試卷
1.概述
在開發(fā)網(wǎng)絡(luò)考試系統(tǒng)時(shí),考試計(jì)時(shí)并自動(dòng)提交試卷是必不可少的功能。由于在答卷過程中,試卷不能刷新,所以需要使用Ajax實(shí)現(xiàn)無刷新操作。運(yùn)行本實(shí)例,訪問準(zhǔn)備考試頁面index.jsp,在該頁面中,單擊“開始考試”按鈕,將打開新窗口顯示開始考試的頁面,如圖10.1所示,頁面會(huì)自動(dòng)計(jì)時(shí),當(dāng)考試時(shí)間結(jié)束時(shí),將自動(dòng)提價(jià)試卷。
2.技術(shù)要點(diǎn)
主要是利用Ajax異步提交技術(shù)和Servlet技術(shù)實(shí)現(xiàn)的。顯示在考試頁面中的計(jì)時(shí)時(shí)間是在Servlet中設(shè)置的,需要通過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); //打開服務(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); //打開服務(wù)器連接 request.onreadystatechange = resFun; //響應(yīng)回調(diào)函數(shù) request.send(null); //發(fā)送請(qǐng)求 } } else{ alert( "該瀏覽器不支持Ajax!" ); } return request; }
(1)新建index.jsp頁,該頁面是用戶訪問的初始頁。在頁面中主要包含一個(gè)“開始考試”按鈕,該按鈕的onclick事件將調(diào)用打開考試窗口的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)建考試的開始時(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類中,編寫用于將頁面轉(zhuǎn)發(fā)到開始考試頁面的方法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頁,用于輸出計(jì)時(shí)開始時(shí)間。關(guān)鍵代碼如下:
<%@page contentType="text/html" pageEncoding="GBK"%> ${showStartTime}
(5)新建showRemainTime.jsp頁,用于輸出計(jì)時(shí)剩余時(shí)間。關(guān)鍵代碼如下:
<%@page contentType="text/html" pageEncoding="GBK"%> ${showRemainTime}
(6)新建開始考試頁面startExam.jsp頁,在該頁中通過調(diào)用Ajax請(qǐng)求方法請(qǐng)求StartExam類,獲得考試的開始時(shí)間和剩余時(shí)間。關(guān)鍵代碼如下:
var request1= false; var request2 = false; //請(qǐng)求Servlet獲得開始時(shí)間 function showStartTime(){ var url = "StartExam"; //此處需要加&nocache="+new Date().getTime(),否則將出現(xiàn)時(shí)間不自動(dòng)走動(dòng)的情況 var parameter="action=showStartTime&nocache="+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=showRemainTime&nocache="+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)頁面加載后自動(dòng)計(jì)時(shí),需要在開始考試頁面的 <body>標(biāo)簽中通過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ì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Jquery基于Ajax方法自定義無刷新提交表單Form實(shí)例
這篇文章主要介紹了Jquery基于Ajax方法自定義無刷新提交表單Form的方法,結(jié)合實(shí)例詳細(xì)分析了Ajax無刷新提交表單的完整實(shí)現(xiàn)過程,并總結(jié)了使用中的注意事項(xiàng),具有很好的借鑒價(jià)值,需要的朋友可以參考下2014-11-11淺析IE針對(duì)Ajax請(qǐng)求結(jié)果的緩存問題
我們通過一個(gè)ASP.NET MVC應(yīng)用來重現(xiàn)IE針對(duì)Ajax請(qǐng)求結(jié)果的緩存。在一個(gè)空ASP.NET MVC應(yīng)用中我們定義了如下一個(gè)默認(rèn)的HomeController,其中包含一個(gè)返回當(dāng)前時(shí)間的Action方法GetCurrentTime。2015-09-09在dom4j中使用XPath的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)硪黄赿om4j中使用XPath的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09HTTP報(bào)文及ajax基礎(chǔ)知識(shí)
客戶端傳遞給服務(wù)器的內(nèi)容 和 服務(wù)器傳遞給客戶端的內(nèi)容 都屬于HTTP報(bào)文。Ajax是客戶端JS中的方法,用來向服務(wù)端發(fā)送請(qǐng)求,下面通過本文給大家分享HTTP報(bào)文及ajax基礎(chǔ)知識(shí),感興趣的朋友一起看看吧2017-08-08利用AjaxControlToolkit實(shí)現(xiàn)百度搜索時(shí)的下拉列表提示詳細(xì)步驟
AjaxControlToolkit是一組控件的集合,可以實(shí)現(xiàn)自動(dòng)補(bǔ)充文本框,點(diǎn)擊文本框彈出日歷,加水印等Ajax效果等等,感興趣的朋友可以了解下啊,或許本文對(duì)你學(xué)習(xí)ajax有所幫助2013-02-02webform使用ajax訪問后端接口的兩種方法小結(jié)
這篇文章主要介紹了webform使用ajax訪問后端接口的兩種方法小結(jié),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-11-11Jquery Ajax請(qǐng)求文件下載操作失敗的原因分析及解決辦法
jQuery確實(shí)是一個(gè)挺好的輕量級(jí)的JS框架,能幫助我們快速的開發(fā)JS應(yīng)用,并在一定程度上改變了我們寫JavaScript代碼的習(xí)慣,本文重點(diǎn)給大家介紹Jquery Ajax請(qǐng)求文件下載操作失敗的原因分析及解決辦法,對(duì)ajax請(qǐng)求失敗的原因分析感興趣的朋友一起學(xué)習(xí)把2015-11-11

jQuery AJAX實(shí)現(xiàn)調(diào)用頁面后臺(tái)方法