91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于Ajax技術如何實現考試倒計時并自動提交試卷

發布時間:2021-08-27 09:57:53 來源:億速云 閱讀:156 作者:小新 欄目:web開發

這篇文章主要介紹基于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=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)為了實現頁面加載后自動計時,需要在開始考試頁面的 <body>標簽中通過onload事件應用window.setInterval()方法調用showStartTime()函數和showRemailTime()函數,關鍵代碼如下:

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

以上是“基于Ajax技術如何實現考試倒計時并自動提交試卷”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

日喀则市| 水城县| 江永县| 浦江县| 沂源县| 崇义县| 象山县| 方山县| 额济纳旗| 铁岭县| 封开县| 洛宁县| 朔州市| 阳新县| 鄂伦春自治旗| 南投县| 封开县| 刚察县| 寿光市| 临西县| 万安县| 汤阴县| 洞口县| 个旧市| 甘谷县| 紫云| 崇信县| 和林格尔县| 株洲县| 永丰县| 原平市| 五家渠市| 崇信县| 大埔县| 兴隆县| 绵竹市| 济宁市| 双江| 河池市| 西宁市| 福鼎市|