日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php考试倒计时提交系统,AJAX_基于Ajax技术实现考试倒计时并自动提交试卷,1.概述在开发网络考试系统 - phpStudy...

發布時間:2024/1/23 php 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php考试倒计时提交系统,AJAX_基于Ajax技术实现考试倒计时并自动提交试卷,1.概述在开发网络考试系统 - phpStudy... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

基于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中設置的,關鍵代碼如下:

StartExam

com.lh.servlet.StartExam

examTime

20

(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頁,用于輸出計時開始時間。關鍵代碼如下:

${showStartTime}

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

${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)為了實現頁面加載后自動計時,需要在開始考試頁面的

標簽中通過onload事件應用window.setInterval()方法調用showStartTime()函數和showRemailTime()函數,關鍵代碼如下:

以上所述是小編給大家介紹的基于Ajax技術實現考試倒計時并自動提交試卷 的相關知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對phpstudy網站的支持!相關閱讀:

php使用ffmpeg獲取視頻信息并截圖的實現方法

解決asp.net mvc UpdateModel更新對象后出現null問題的方法

NodeJS使用jQuery選擇器操作DOM

使用php批量刪除數據庫下所有前綴為prefix_的表

android Handler詳細使用方法實例

JS 刪除字符串最后一個字符的實現代碼

mac版阿里旺旺怎么下載 mac版阿里旺旺下載安裝使用圖文教程

Javascript實現的常用算法(如冒泡、快速、鴿巢、奇偶等)

jQuery常用的一些技巧匯總

詳解Android中的Context抽象類

最簡單的SD卡文件遍歷Android程序

css背景應用中的repeat-x與repeat-y各是什么意思

一個看起來比較舒服值得學習的文本框樣式

Win8.1怎么升級最新Win10系統 Win8.1通過update升級Win10圖文教程

總結

以上是生活随笔為你收集整理的php考试倒计时提交系统,AJAX_基于Ajax技术实现考试倒计时并自动提交试卷,1.概述在开发网络考试系统 - phpStudy...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。