Ajax技术原理及其在选课系统中的应用

时间:2024-04-26 03:02:31 5A范文网 浏览: 论文范文 我要投稿

   摘  要  Ajax技术是目前深受Web用户欢迎的一项技术,它利用JavaScript、DOM、XML和XMLHttpRequest实现客户端与服务器的异步交互,达到很好的用户体验。文中介绍的选课系统运用Ajax技术,提高了系统的运行效率。

    关键词  Ajax技术;Web服务器;XMLHttpRequest;选课系统 


 

1  引言

    在传统的Web应用中,大部分用户动作会触发一个连接到Web服务器的HTTP请求,服务器收到请求后要完成诸如验证合法性、计算数据、访问数据库等处理工作,最后返回一个HTTP页面到客户端,这个过程中用户一直处于等待状态。随着Web技术的广泛应用,人们对Web应用程序提出了更高的要求,Web不再简单应用于发布网站,而是成为许多业务处理平台,于是人们更加注重流畅、快捷、人性化的用户体验,为了满足这一需求,一种新的技术出现了,它就是Ajax,它使Web应用程序继承了桌面应用程序反应灵敏、胖客户端、客户体验优秀等优点。

2  Ajax的工作原理

2.1  Ajax工作方式

    Ajax(Asynchronous JavaScript and XML)技术实际上是在客户端和服务器之间加入一个Ajax引擎,它允许采用异步的方式实现客户端与服务器的交互,所以用户不用打开空白窗口等待服务器的响应,而可以继续进行客户端的其它工作。服务器响应完毕之后,将结果提交给Ajax引擎,Ajax引擎使用HTML和CSS技术展示给用户。客户端和服务器的这种异步通信,使用户感觉不到客户端与服务器的通信,使得Web程序看起来是即时响应的。图1显示了Ajax的工作方式。图1  Ajax的工作方式    在传统的Web应用中,客户端只是通过浏览器简单的显示内容,所有的信息都保存在服务器上,引入Ajax后,它把一部分Web应用程序移到了浏览器中,使浏览器中不再是纯粹的内容。用户登录时,浏览器会从服务器下载大量代码,这些代码具有一定的处理用户请求的能力,由它们来决定是否将用户的请求提交给服务器。由于用户的一部分请求可以直接在客户端进行处理,客户端与服务器的通信效率会提高许多。

2.2  Ajax关键技术

    Ajax技术并不是一种孤立的技术,它是由多种技术综合而成的,这些技术包括:JavaScript、DOM、XML和XMLHttpRequest,这些技术按照一定的方式发挥各自的作用构成Ajax技术。DOM实现动态显示和交互,XML进行数据交换与处理,XMLHttpRequest进行异步数据读取,JavaScript用于邦定和处理所有数据。    1)JavaScript    JavaScript是一种基于对象和事件驱动的脚本语言,具有很好的安全性,它通过嵌入在标准的HTML语言中完成各种与用户交互的任务。Ajax利用JavaScript的特性实现对用户行为的实时响应与处理,JavaScript还能通过其属性和方法操作DOM,将用户请求通过XMLHttpRequest对象实现与服务器的异步交互通信。    2)DOM    DOM(Document Object Model)是一个能够让程序和脚本动态访问和更新文档内容、结构和样式的语言平台,它提供了标准的HTML和XML对象集,并由一个标准的接口来访问并操作它们。DOM是一个树型结构,由元素和节点组成,它是以面向对象的方式描述的对象模型。DOM对象分为HTML DOM对象和XML DOM对象。    3)XML    XML (eXtensible Markup Language) 是可扩展标记语言的缩写,它通常作为数据传输的媒介,服务器采用返回XML文本的方式将响应后的数据返回给客户端。在应用Ajax技术时,XMLHttpRequest对象可以使用XML作为与服务器端通信的数据格式。    4)XMLHttpRequest    XMLHttpRequest是Ajax技术体系中最为核心的技术,它负责将用户信息以异步方式发送到服务器,并接收服务器返回的响应信息和数据。Web应用程序无需刷新页面就可以向服务器提交信息,或从服务器得到应答,这样用户就不会觉察后台向服务器提交和接收数据,而且,客户端也不必每次都将数据处理工作交给服务器来做,这样加快了响应速度,也就缩短了用户的等待时间。

3  Ajax在选课系统中的应用

3.1  系统功能分析

    系统按功能划分为三个模块:学生选课模块、教师开课模块、管理员管理模块。如图2所示。各模块功能相对独立,学生选课模块包括修改个人信息和选课。教师开课模块包括修改个人信息、浏览基本课程列表、查看学生选课信息、申请开课。管理员管理模块包括为教师和学生分配帐号密码、注销或修改用户状态、创建课程和指定任课教师、为课程班级设定人数、对学生选课信息进行统计、通知学生和老师选课结果和选课时间等。三个模块都需要经过注册、登录后才能实现。图2  选课系统功能模块



  [8]电大学习网.免费论文网[EB/OL]. /d/file/p/2024/0424/fontbr /> 

3.2  Ajax在系统中的应用

    本系统中用户注册、修改个人信息、选课、申请教课等功能的实现需要客户端向服务器发出HTTP请求,服务器收到请求后进行验证、访问数据库等处理,处理完毕后刷新页面。其间用户一直处于等待状态,如果出现断电、网络故障或信息填写不当等意外事件,用户需要重新填写大量信息,这样既降低了系统的运行效率,也给用户带来诸多不便。    引入Ajax技术后,用户填写完信息由XMLHttpRequest提交给服务器进行处理,用户可以继续其它操作,如果验证不合格客户端可立即得到通知,而不必重新下载整个网页,如果出现意外情况也可从服务器获得已填写的信息。以下以注册部分关键代码为例说明Ajax应用。1)创建XMLHttpRequest对象function createXMLHttpRequest()  {    if (window.ActiveXObject) {       if(navigator.userAgent.toLowerCase().indexOf ('msie 5')!= -1)  {          xmlHttp = new ActiveXObject ("Microsoft. XMLHTTP");}       else {         xmlHttp = new ActiveXObject("Msxml2. XMLHTTP");}                          }     else if (window.XMLHttpRequest)  {        xmlHttp = new XMLHttpRequest();}     else {       alert("创建XMLHttpRequest失败!");} }2)XMLHttpRequest发送请求function checkUser(userId){        //check userName                    var userObj = document. getElement ById(userId);                    var url = "checkUser.asp?userName=" +escape(userObj.value);//请求的URL                    xmlHttp.open("GET",url,true);//true:异步方式                  xmlHttp.onreadystatechange = checkUserOk;//指定状态变化时触发的事件句柄xmlHttp.send(null); ///发送信息}3)XMLHttpRequest处理服务器响应function checkUserOk(){              //check userName ready     if (xmlHttp.readyState ==4) {   //完成var response = xmlHttp.response Text;                       var alertObj = document. Get ElementById ("reg_alert");                   if(response == "该帐号已注册"){                              alertObj.innerHTML="对不起,<br/>此用户已经注册!";                   }else if(response == "帐号为空"){                               alertObj.innerHTML="对不起,<br/>用户名不能为空!";                   }else if(response == "帐号未注册"){                               alertObj.innerHTML = "<span class ='blue_txt'>此用户名可用!</span>";                    }else if(response == "帐号不存在"){                               alertObj.innerHTML="对不起,<br/>用户名不可用!";}}  }

4  结束语

    Ajax技术并不是一项复杂的技术,但是它很好地利用了几项技术的融合,达到了令人满意的效果,成为深受Web用户喜爱的一项技术。本选课系统主要在用户注册、修改个人信息、填写选课信息、申请教课页面运用Ajax技术,该技术避免了用户多次填写大量信息的烦恼,缩短了用户的等待时间,充分体现了Ajax技术的优点。

参考文献

[1] 曹衍龙,叶达峰.Ajax编程技术与实例[M].北京:人民邮电出版社,2007.5[2] Ryan Asleson,Nathaniel T Schutta. Ajax 基础教程[M] . 北京:人民邮电出版社,2006[3] 尹永田,葛苏慧,任佳.基于ASP.NET 的网上选课系统的设计与实现[J]. 中国现代教育装备,2006,12[4] 柯昌正,黄厚宽.Ajax 技术的原理与应用[J].铁路计算机应用,2007,1[5]David Flanagan. JavaScript权威指南[M]. 北京:机械工业出版社,2003[6]Dynamic Html and XML:The XMLHttpRequest Object[EB/OL].http://developer.apple.com/internet/webcon tent/xmlhttpreq.html[7] BrettMcLaughlin. AJAX简介[EB/OL]. http://blog.csdn. net/lithe/archive/2006/02/22/605234. aspx


  [8]电大学习网.免费论文网[EB/OL]. /d/file/p/2024/0424/fontbr /> 

相关文章:

基于混沌序列和浮点小波变换的盲水印04-26

南开大学伯苓学院本科生二作发表Nature论文04-26

研究生为何频频在国际学术刊物发表论文——厦门大学多04-26

三维彩色逆向工程技术研究04-26

一种基于SOA架构的EAI研究与设计04-26

NET中对象序列化方法04-26

今年重庆中小学正高级教师指标数113个 论文不作教师评04-26

四川多领域职称评定 对论文外语计算机已不统一要求04-26

云教学同向同行 融思政如盐入味大连海洋大学在线教学04-26

2020年诺贝尔文学得主露易丝·格丽克诗歌选读04-26

热搜文章
最新文章