婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于Ajax技術實現考試倒計時并自動提交試卷

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

熱門標簽:地圖標注項目怎么樣 越南河內地圖標注 ai機器人電銷資源 云呼外撥網絡電話系統 超級大富翁地圖標注 個人怎樣在百度地圖標注地名 硅語電話機器人公司 騰訊地圖標注位置能用多久 機器人電銷騙局揭秘

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,技術,實現,考試,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于Ajax技術實現考試倒計時并自動提交試卷》相關的同類信息!
  • 本頁收集關于基于Ajax技術實現考試倒計時并自動提交試卷的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲男女毛片无遮挡| 亚洲午夜电影在线| 亚洲人成亚洲人成在线观看图片 | 国产一区二区三区久久悠悠色av| 欧美日韩国产一区| 亚洲国产视频网站| 欧美一区二区福利视频| 狠狠色综合播放一区二区| 精品国产乱码久久久久久蜜臀 | 日韩激情av在线| 欧美日韩成人一区二区| 日av在线不卡| 中文字幕二三区不卡| 99久久伊人久久99| 亚洲一区二区三区四区五区中文| 欧美日韩免费一区二区三区| 一区二区三区欧美久久| 欧美一区二区三区免费视频| 久久久久亚洲综合| 不卡欧美aaaaa| 国产精品剧情在线亚洲| 亚洲123区在线观看| 91精品福利视频| 国产欧美精品区一区二区三区| 久久se精品一区精品二区| 日韩一级视频免费观看在线| 不卡的av在线播放| 亚洲精品久久嫩草网站秘色| 在线免费观看日本一区| 国产精品原创巨作av| 国产精品毛片大码女人| 在线观看日韩一区| 国产精品一二三区| 亚洲乱码国产乱码精品精可以看 | 欧美色爱综合网| 亚洲大片免费看| 欧美精品三级在线观看| 岛国av在线一区| 亚洲六月丁香色婷婷综合久久 | 一本大道av一区二区在线播放 | 欧美性大战久久久久久久| 精品综合免费视频观看| 国产农村妇女毛片精品久久麻豆| 色狠狠av一区二区三区| 蜜桃视频第一区免费观看| 欧美国产精品v| 精品国产凹凸成av人网站| av影院午夜一区| 天天操天天色综合| 亚洲乱码日产精品bd| 日韩欧美国产一区二区在线播放 | 黄色精品一二区| 五月天激情综合| 国产精品少妇自拍| 成人国产一区二区三区精品| 亚洲成人av一区二区| 久久综合国产精品| gogo大胆日本视频一区| 国产乱一区二区| 午夜欧美2019年伦理| 2023国产一二三区日本精品2022| 色哟哟国产精品| 国产精品资源站在线| 国产高清亚洲一区| 亚洲一区二区三区激情| 国产99精品视频| 免费在线观看视频一区| 自拍偷自拍亚洲精品播放| 亚洲三级电影网站| 国产欧美日韩不卡| 2023国产精品| 中文字幕一区二区三区精华液| 日韩一级黄色片| 国产精品 欧美精品| 国产在线精品一区二区不卡了| 亚洲一区av在线| 日韩欧美一区二区三区在线| 日韩美女天天操| 欧美精品aⅴ在线视频| 日韩欧美精品在线视频| 欧美一区二区视频网站| 欧美日韩午夜在线视频| 8v天堂国产在线一区二区| 一本大道综合伊人精品热热| 成人18视频日本| 欧美日韩国产不卡| 欧美日韩国产影片| 欧美日韩久久一区| 欧美美女视频在线观看| 国产精品久久久久久久久免费相片 | 自拍偷拍欧美精品| 欧美国产精品中文字幕| 国产人妖乱国产精品人妖| 亚洲免费色视频| 一区二区成人在线视频| 久久亚洲综合色一区二区三区 | 欧美日韩视频专区在线播放| 欧美最新大片在线看| 91麻豆精品91久久久久久清纯| 欧美人与z0zoxxxx视频| 91.成人天堂一区| 中文字幕在线观看一区| 一区二区三区电影在线播| 亚洲国产精品一区二区久久恐怖片 | 黄色日韩三级电影| 黄一区二区三区| 国产精品天美传媒沈樵| 日韩不卡一区二区三区| 精品在线一区二区三区| 欧美视频一区二区在线观看| 欧美久久久久久蜜桃| 精品国产三级电影在线观看| 亚洲国产精品久久不卡毛片| 免费观看成人av| 国产成人福利片| 精品久久久久久久久久久院品网| 久久青草国产手机看片福利盒子| 午夜久久福利影院| 高清不卡一二三区| 欧美亚一区二区| 综合久久久久久久| 蜜臀久久久久久久| 波多野结衣一区二区三区 | 在线看国产日韩| 欧美一级黄色大片| 丝袜美腿亚洲一区| 国产一区在线观看麻豆| 成人免费看黄yyy456| 日韩午夜电影在线观看| 中文字幕佐山爱一区二区免费| 国产成人免费高清| 欧美精品v日韩精品v韩国精品v| 久久精品欧美一区二区三区不卡 | 国产精品午夜电影| 午夜精品免费在线| 不卡一区二区三区四区| 欧美一区欧美二区| 亚洲精品日韩一| 在线国产电影不卡| 欧美国产精品中文字幕| 国产福利视频一区二区三区| 在线观看免费成人| 国产亚洲va综合人人澡精品| 国产精品一区免费在线观看| 欧美丰满少妇xxxxx高潮对白| 欧美国产乱子伦| 国产一区二区三区免费观看| 欧美午夜理伦三级在线观看| 亚洲一区在线视频| 99免费精品视频| 国产日韩精品一区| 91亚洲国产成人精品一区二三 | 欧美日韩日日摸| 久久久久久久久免费| 懂色av一区二区三区免费观看| 在线综合视频播放| 精品一区二区三区在线播放| 欧美人动与zoxxxx乱| 久久精品国产一区二区三区免费看| 精品国产乱码久久久久久影片| 高清在线成人网| 夜夜夜精品看看| 精品久久国产老人久久综合| 成人黄色电影在线 | 99久久婷婷国产精品综合| 亚洲最快最全在线视频| 欧美成人一区二区三区片免费 | 亚洲一区二区欧美日韩| 亚洲精品一线二线三线无人区| 成人精品鲁一区一区二区| 五月婷婷色综合| 国产日韩欧美制服另类| 91欧美一区二区| 狠狠色狠狠色综合系列| 亚洲精品中文在线观看| 欧美变态tickling挠脚心| 99久久精品国产网站| 麻豆国产精品视频| 亚洲成人资源网| 中文字幕日韩一区| 欧美va亚洲va国产综合| 色老汉一区二区三区| 狠狠狠色丁香婷婷综合激情 | 日韩精品专区在线影院观看| 欧美a级理论片| 国产日韩一级二级三级| 欧美日韩国产bt| 黄一区二区三区| 亚洲成a人在线观看| 精品国产一区二区三区av性色| 热久久一区二区| 亚洲蜜臀av乱码久久精品 | 一区二区三区 在线观看视频| 日韩色在线观看| 波多野结衣精品在线| 国产寡妇亲子伦一区二区| 亚洲精品乱码久久久久久久久 | 欧美一区午夜精品| 成人一区二区三区在线观看| 精品一区二区三区在线播放视频|