


Implementing exam countdown and automatically submitting test papers based on Ajax technology
This article mainly introduces relevant information on implementing exam countdown and automatically submitting test papers based on Ajax technology. It is very good and has the value of reference and learning ajax. Friends who are interested in ajax can refer to it
1. Overview
When developing an online exam system, exam timing and automatic submission of test papers are essential functions. Since the test paper cannot be refreshed during the answering process, Ajax needs to be used to implement refresh-free operation. Run this example and access the exam preparation page index.jsp. In this page, click the "Start Exam" button. A new window will open to display the page to start the exam, as shown in Figure 10.1. The page will automatically time the time when the exam time ends. At this time, the price of the test paper will be automatically increased.
2. Technical points
is mainly implemented using Ajax asynchronous submission technology and Servlet technology. The timing time displayed on the exam page is set in the Servlet, and it is necessary to continuously request the Servlet through Ajax asynchronous submission to obtain the latest timing time data returned by the server. In order to facilitate maintenance and code reuse, Ajax's request method can be encapsulated into a JS file. This method can be used as a public method and can be called directly when used in the program.
3. Specific implementation code
#Construct the XMLHttpRequest object and request method in the JS file, as shown in the following code :
/** * 构建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) Create a new index.jsp page, which is the initial page visited by users. The page mainly contains a "Start Exam" button. The button's onclick event will call the JavaScript function that opens the exam window. The key code is as follows:
##
function showWindow(){ window.open('StartExam?action=startExam','','width=750,height=500,scrollbars=1'); }
<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>
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); }
<%@page contentType="text/html" pageEncoding="GBK"%> ${showStartTime}
<%@page contentType="text/html" pageEncoding="GBK"%> ${showRemainTime}
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 ){ showStartTimep.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; showRemainTimep.innerHTML=h; h=h.replace(/\s/g,""); //去除字符串中的Unicode空白符 showRemainTimep.innerHTML=h; if(h=="00:00:00"){ form1.submit(); } } } }
<body onLoad="showStartTime();showRemainTime();" onkeydown="keydown()">
Ajax quick solution The parameter is too long and cannot be submitted successfully. How to solve it
Ajax submission Form form page will still refreshj Solution
AJAX display is loading and the layer occlusion page pops up
The above is the detailed content of Implementing exam countdown and automatically submitting test papers based on Ajax technology. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

How to implement dual WeChat login on Huawei mobile phones? With the rise of social media, WeChat has become one of the indispensable communication tools in people's daily lives. However, many people may encounter a problem: logging into multiple WeChat accounts at the same time on the same mobile phone. For Huawei mobile phone users, it is not difficult to achieve dual WeChat login. This article will introduce how to achieve dual WeChat login on Huawei mobile phones. First of all, the EMUI system that comes with Huawei mobile phones provides a very convenient function - dual application opening. Through the application dual opening function, users can simultaneously

The programming language PHP is a powerful tool for web development, capable of supporting a variety of different programming logics and algorithms. Among them, implementing the Fibonacci sequence is a common and classic programming problem. In this article, we will introduce how to use the PHP programming language to implement the Fibonacci sequence, and attach specific code examples. The Fibonacci sequence is a mathematical sequence defined as follows: the first and second elements of the sequence are 1, and starting from the third element, the value of each element is equal to the sum of the previous two elements. The first few elements of the sequence

Build an autocomplete suggestion engine using PHP and Ajax: Server-side script: handles Ajax requests and returns suggestions (autocomplete.php). Client script: Send Ajax request and display suggestions (autocomplete.js). Practical case: Include script in HTML page and specify search-input element identifier.

How to implement the WeChat clone function on Huawei mobile phones With the popularity of social software and people's increasing emphasis on privacy and security, the WeChat clone function has gradually become the focus of people's attention. The WeChat clone function can help users log in to multiple WeChat accounts on the same mobile phone at the same time, making it easier to manage and use. It is not difficult to implement the WeChat clone function on Huawei mobile phones. You only need to follow the following steps. Step 1: Make sure that the mobile phone system version and WeChat version meet the requirements. First, make sure that your Huawei mobile phone system version has been updated to the latest version, as well as the WeChat App.

In today's software development field, Golang (Go language), as an efficient, concise and highly concurrency programming language, is increasingly favored by developers. Its rich standard library and efficient concurrency features make it a high-profile choice in the field of game development. This article will explore how to use Golang for game development and demonstrate its powerful possibilities through specific code examples. 1. Golang’s advantages in game development. As a statically typed language, Golang is used in building large-scale game systems.

How to solve the problem of jQueryAJAX error 403? When developing web applications, jQuery is often used to send asynchronous requests. However, sometimes you may encounter error code 403 when using jQueryAJAX, indicating that access is forbidden by the server. This is usually caused by server-side security settings, but there are ways to work around it. This article will introduce how to solve the problem of jQueryAJAX error 403 and provide specific code examples. 1. to make

PHP Game Requirements Implementation Guide With the popularity and development of the Internet, the web game market is becoming more and more popular. Many developers hope to use the PHP language to develop their own web games, and implementing game requirements is a key step. This article will introduce how to use PHP language to implement common game requirements and provide specific code examples. 1. Create game characters In web games, game characters are a very important element. We need to define the attributes of the game character, such as name, level, experience value, etc., and provide methods to operate these

Using Ajax to obtain variables from PHP methods is a common scenario in web development. Through Ajax, the page can be dynamically obtained without refreshing the data. In this article, we will introduce how to use Ajax to get variables from PHP methods, and provide specific code examples. First, we need to write a PHP file to handle the Ajax request and return the required variables. Here is sample code for a simple PHP file getData.php:
