欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2016年06月16日 15:18:09   作者:柯南&  
這篇文章主要介紹了基于Ajax技術(shù)實現(xiàn)考試倒計時并自動提交試卷 的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

1.概述

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

2.技術(shù)要點

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

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

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

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

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

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

(2)新建名為StartExam的Servlet實現(xiàn)類,該類用創(chuàng)建考試的開始時間和剩余時間。在該類中,創(chuàng)建一個全局變量examTime,用于記錄考試時間,該變量的值是在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); //保存考試時間
session.setAttribute("startTime1",new Date().getTime()); //保存當前時間的毫秒數(shù)
request.getRequestDispatcher("startExam.jsp").forward(request, response);
} 

(4)新建showStartTime.jsp頁,用于輸出計時開始時間。關(guān)鍵代碼如下:

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

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

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

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

var request1= false;
var request2 = false;
//請求Servlet獲得開始時間 
function showStartTime(){
var url = "StartExam";
//此處需要加&nocache="+new Date().getTime(),否則將出現(xiàn)時間不自動走動的情況
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;
}
}
}
//請求Servlet獲得剩余時間 
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)為了實現(xiàn)頁面加載后自動計時,需要在開始考試頁面的 <body>標簽中通過onload事件應用window.setInterval()方法調(diào)用showStartTime()函數(shù)和showRemailTime()函數(shù),關(guān)鍵代碼如下:

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

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

相關(guān)文章

  • Jquery基于Ajax方法自定義無刷新提交表單Form實例

    Jquery基于Ajax方法自定義無刷新提交表單Form實例

    這篇文章主要介紹了Jquery基于Ajax方法自定義無刷新提交表單Form的方法,結(jié)合實例詳細分析了Ajax無刷新提交表單的完整實現(xiàn)過程,并總結(jié)了使用中的注意事項,具有很好的借鑒價值,需要的朋友可以參考下
    2014-11-11
  • [asp]天楓AJAX blog V1.0 程序提供下載了

    [asp]天楓AJAX blog V1.0 程序提供下載了

    [asp]天楓AJAX blog V1.0 程序提供下載了...
    2007-09-09
  • 淺析IE針對Ajax請求結(jié)果的緩存問題

    淺析IE針對Ajax請求結(jié)果的緩存問題

    我們通過一個ASP.NET MVC應用來重現(xiàn)IE針對Ajax請求結(jié)果的緩存。在一個空ASP.NET MVC應用中我們定義了如下一個默認的HomeController,其中包含一個返回當前時間的Action方法GetCurrentTime。
    2015-09-09
  • 在dom4j中使用XPath的簡單實例

    在dom4j中使用XPath的簡單實例

    下面小編就為大家?guī)硪黄赿om4j中使用XPath的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • HTTP報文及ajax基礎(chǔ)知識

    HTTP報文及ajax基礎(chǔ)知識

    客戶端傳遞給服務(wù)器的內(nèi)容 和 服務(wù)器傳遞給客戶端的內(nèi)容 都屬于HTTP報文。Ajax是客戶端JS中的方法,用來向服務(wù)端發(fā)送請求,下面通過本文給大家分享HTTP報文及ajax基礎(chǔ)知識,感興趣的朋友一起看看吧
    2017-08-08
  • 利用AjaxControlToolkit實現(xiàn)百度搜索時的下拉列表提示詳細步驟

    利用AjaxControlToolkit實現(xiàn)百度搜索時的下拉列表提示詳細步驟

    AjaxControlToolkit是一組控件的集合,可以實現(xiàn)自動補充文本框,點擊文本框彈出日歷,加水印等Ajax效果等等,感興趣的朋友可以了解下啊,或許本文對你學習ajax有所幫助
    2013-02-02
  • webform使用ajax訪問后端接口的兩種方法小結(jié)

    webform使用ajax訪問后端接口的兩種方法小結(jié)

    這篇文章主要介紹了webform使用ajax訪問后端接口的兩種方法小結(jié),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-11-11
  • Jquery Ajax請求文件下載操作失敗的原因分析及解決辦法

    Jquery Ajax請求文件下載操作失敗的原因分析及解決辦法

    jQuery確實是一個挺好的輕量級的JS框架,能幫助我們快速的開發(fā)JS應用,并在一定程度上改變了我們寫JavaScript代碼的習慣,本文重點給大家介紹Jquery Ajax請求文件下載操作失敗的原因分析及解決辦法,對ajax請求失敗的原因分析感興趣的朋友一起學習把
    2015-11-11
  • ajax分頁查詢詳解

    ajax分頁查詢詳解

    本文主要介紹了ajax實現(xiàn)分頁查詢的步驟與方法。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • jQuery AJAX實現(xiàn)調(diào)用頁面后臺方法

    jQuery AJAX實現(xiàn)調(diào)用頁面后臺方法

    這篇文章主要為大家詳細介紹了jQuery AJAX實現(xiàn)調(diào)用頁面后臺方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-05-05

最新評論