`
hold_on
  • 浏览: 456563 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论
阅读更多

 1、什么是AJAX?


AJAX = 异步 JavaScript 及 XML(Asynchronous JavaScript and XML)
AJAX 不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的 Web 应用程序的技术。通过 AJAX,您的 JavaScript

可使用 JavaScript 的 XMLHttpRequest 对象来直接与服务器进行通信。通过这个对象,您的 JavaScript 可在不重载页面的情况与

Web 服务器交换数据。


2、AJAX中用到的技术

实际上,Ajax 不是一种技术,而是几种技术。每种技术都具有独特之处,合在一起就形成功能强大的新技术。Ajax 包括:

javaScript: 实现客户端的数据发送和界面更新,是ajax 实现的编程语言;

XMLHttpRequest : 浏览器内置的用以进行异步数据发送和接收的对象,是AJAX 核心对象;

  Css+div: 对用户而言,AJAX 的价值是用户界面更加友好--- 这当然还是依靠css+div 实现;

  DOM 模型: AJAX 常见的技巧就是使用js 响应dom 组件事件或更新其;

  Xml: XML 仅是一种传输数据的格式,在ajax 应用中常以xml 格式在c/s 间交换数据;

  Html: 这个不用说了,浏览器上展示东东归根到底是靠这玩意。

    如果你在实践本节应用时,对css+div+dom 技巧还不是很熟练,就做做边回头看我们前面所讲的css+div 和js+dom 技术的教程



你可能很奇怪,AJAX 技术中没有java 的身影。即确如此,AJAX 所关注的是,如何在用户端的展示,即浏览器上,java 的代码,除

了正在淘汰中的applet, 是不可能跑到游览器上的。可以这样理解:ajax 是独立与后端服务器的一种技术,应用AJAX 时,与后端采

用何种编程语言无关, 当然与你对这种语言的熟练程序有关。

3、AJAX与传统web的区别

传统web都是“请求--响应”模式,如果客户需要与服务器进行交互,比如说,登陆界面,当客户输入的用户名和密码有误时,应该在

登录页面给予错误提示,按照传统web,流程是这样的:

1、浏览器提交登录请求

2、服务器解析请求,用户名或密码错误,给予响应,再重发整个登录界面给客户

3、浏览器接收服务器响应(这时客户端接收的是服务器响应后的整个登陆界面(即页面刷新),而其区别仅仅比登陆前的界面多出

了一个,这显然不是我们希望的)

而AJAX代码运行在浏览器和服务器之间,通过编程,你可以让AJAX代码(核心:XMLHttpReques异步请求对象)从服务器仅提取需要

改变的数据,也只改变页面中需要改变的某一部分,按照AJAX,以上登录过程流程是这样的:

1、浏览器提交登录请求

2、服务器解析请求,用户名或密码错误,给予响应,仅仅发送“错误提示”部分数据给客户

3、浏览器通过AJAX中的XMLHttpRequest(异步请求对象)解析服务器响应客户请求的数据,再在客户端本地进行处理(显示登录的错

误提示),注意:此时浏览器并没有重新刷新页面


下面我们用AJAX来写一个登陆界面对重复用户名的验证

AJAX三部曲:

第一步、创建XMLHttpReques对象

< script type = "text/javascript" >

// 定义了XMLHttpRequest 对象

  var request;

   // 创建XMLHttpRequest 对象函数

     function getRequestObject() {

        if (window.ActiveXObject) { //判断客户端浏览器是否是IE

          request= new ActiveXObject( "Microsoft.XMLHTTP" );

        } else if (window.XMLHttpRequest) { //判断客户端浏览器是否是firefox或者其他浏览器

          request= new XMLHttpRequest();

        } else {

          window.alert( " 你的浏览器不支持XMLHTTPRequest ,将无使用AJAX 功能!" );

        }

     }

  </ script >
 


第二步、编写回调方法:

  // 回调方法实现: 将服务器返回的消息更新到div 中

function processResult() {

       if ((request.readyState == 4) &&

             (request.status == 200)) {

          //1. 弹出对话框以便调试

         alert( " 服务器返回的是: " +request.responseText);

         // 显示到指定的组件中

       document.getElementById( "divErrorName" ).innerHTML=request.responseText;

        }

     }
 



回调方法:实际上就是一个监听器,当浏览器状态满足request.status == 200&& request.readyState == 4时,浏览器成功接收服

务器发送过来的响应,再在本地对数据进行处理,对响应的html页面做出改变

关于readyState和status参数的值的意义:

readyState:

第一如果返回0:则表示XMLHTTPRequest对像已经创建成功,但并没有初始化,open方法还没有调用.只是做好了工作准备而已.

第二如果返回1:则表示XMLHTTPRequest已经开始工作,并调用了open方法,而且根据open方法里的参数开始向
服务端发送请求.

第三如果返回2:则代表服务端已收到了请求.并且已向客户端传回了被请求的原始数据,此时返回的数据还不能够供客户端使用,

只是为responseText或responseXML接收数据做准备.

第四如果返回3:则表示正在解析原始数据.将原始数据解析为可以responseText,responseXML,responseBody接收到的格式,但还不

能获取.

第五如果返回4:则表示数据解析完毕.整个发送和传回过程一切正常.可以使用responseText,responseXML,responseBody获取数据

另外值得一提的是:其实readyState每改变一次状态.都会触发XMLHTTPRequest对像中的onreadystatechange属性.


status:

200:OK 一切正常,对GET和POST请求的应答文档跟在后面。


关于readyState和status的区别:

readyState是返回XMLHTTPRequest本身的请求工作状态.而status是返回当前http请求状态.想要知道当前的http请求有没有成功

status会返回详细结果.当然只有在readyState状态为3或4的时候,才可以调用status属性。


第三步:发送异步请求

// 发送请求, 绑定回调方法

  function sendRequest() {

          // 创建XMLHTTPRequest 对象

          getRequestObject();

           // 绑定回调方法,

          request.onreadystatechange=processResult;

          // 发送请求

         // request.open("GET", "index.jsp", true);

         // 发送Post 请求

          request.open( "POST" , "servlet/CheckUserNameServlet" , true );

        //设置XMLHttpRequest对像请求的http头:要提交的数据类型

          request.setRequestHeader( "Content-Type" , "application/x-www-form-urlencoded" );

          var userName=document.getElementById( "userName" ).value;

          // 将userName 做为请求参数发送上去

          request.send( "userName=" +userName);

        }
 


以下是页面的html代码:

< html >< head >

< meta http-equiv = "Content-Type" content = "text/html; charset=GBK" >

< title > AJAX 检测重复用户名 蓝杰信息@NetJava.cn </ title >

</ head >

< body >

 

< br > 注册用户名: < input type = "text" name = "userName" />

<!-- 这个div 层内将显示ajax 从服务器返回的消息 -->

< div id = divErrorName " style = "color:red;" ></ div >

< br > 注册  密码: < input type = "password" name = "userPWD" />

< br >< input type = "button" name = "regUser" value = " 注册" />

</ body >

</ html >
 



后台CheckUserNameServlet中的service方法如下:

response.setContentType( "text/html;charset=GBK" );

    PrintWriter out = response.getWriter();

        String userName=request.getParameter( "userName" );

        System. out .println(System.currentTimeMillis ()+ " 请求参数userName: " +userName);

        String temMsg= "" ;

        if ( null ==userName||userName.equals( "" )){

            temMsg= "<h3> 必须输入注册用户名!</h3>" ;

        } else {

        // 假设到数据库表中查找看是否有重名存在:

        //boolean hasName=DBA.checkUserName(userName);

            temMsg= "<h3> 要注册的用户名" +userName+ " 己存在!</h3>" ;

        }

        out.println(temMsg);

        out.flush();

        out.close();
 



总之一句话概括AJAX主要作用:即在不重载页面的情况与 Web 服务器交换数据。

分享到:
评论

相关推荐

    WebService和Ajax总结

    **WebService和Ajax总结** 在IT领域,WebService和Ajax是两种重要的技术,它们分别在Web应用程序的交互和用户体验提升上发挥了重要作用。本篇文章将全面探讨这两种技术的原理、应用及其在.NET环境下的实现。 **一...

    ajax总结:formdata,get,post,ajax等

    ajax总结,load,get,post,ajax总结,还有formdata~~~

    ajax总结,自己的总结

    很好的ajax总结,有助于刚学ajax的初学者

    jQuery和AJAX总结[定义].pdf

    【jQuery和AJAX总结】 jQuery是一个广泛应用于网页开发的JavaScript库,它的主要目的是简化JavaScript的使用,让开发者能够更高效地处理DOM操作、事件处理、动画效果以及与服务器的异步通信。jQuery的核心特性包括...

    Jquery Ajax总结性文档示例

    ### Jquery Ajax总结性文档知识点解析 #### 一、引言 JQuery 是一款轻量级的 JavaScript 库,以其简化 HTML 文档遍历、事件处理、动画以及 Ajax 交互而闻名。Ajax(Asynchronous JavaScript and XML)是一种在无需...

    对AJAX总结记录 为什么要用ajax?

    对AJAX总结记录 为什么要用ajax?

    开发Ajax总结

    ### 开发Ajax总结 #### 一、Ajax概述 ##### 1.1 什么是Ajax **Ajax**(Asynchronous JavaScript and XML)是一种创建交互式网页应用的技术。它通过在后台与服务器进行少量数据交换的方式,使网页能够实现局部更新...

    初学者必看的Ajax总结篇

    一、Ajax简介、优劣势、应用场景以及技术 Ajax简介 : Asynchronous Javascript And XML (异步的JavaScript和XML) 它并不是一种单一的技术,而是有机利用一系列交互式网页应用相关的技术所形成的结合体 AJAX 是...

    ajax总结.doc

    一些基础的ajax点,帮助大家在使用ajax的同时,能够更深入的了解和体验。有了Ajax之后,就可以实现在网页不跳转不刷新的情况下,在网页后台提交数据,部分更新页面内容。

    AJAX技术 详细总结

    自己总结的非常好的AJAX总结,用于页面的一种非常流行的技术。

    mvc中ajax总结及运用

    ajax的基本运用和js的复习,能够实现一些很好的效果,没有用过的朋友可以用用

    ajax自我总结(初版)

    ajax自我总结 ajax自我总结 ajax自我总结 ajax自我总结

    jQuery ajax总结

    总结jQuery的AJAX功能提供了丰富的API,简化了与服务器端的异步通信。无论是简单的GET和POST请求,还是复杂的设置和回调,jQuery都提供了简洁易用的接口。理解并掌握这些知识点对于前端开发工作至关重要,可以有效...

    AJAX_技术总结_设计模式

    **AJAX 技术总结与设计模式** AJAX(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使网页实现异步更新,提升了用户体验。...

    AJAX技术总结.doc

    ### AJAX技术精析 #### 一、AJAX技术概述 AJAX,即"Asynchronous JavaScript and XML"(异步JavaScript和XML),是一种用于构建交互式网页应用的网页开发技术。它结合了多种关键技术,包括XHTML+CSS用于表现,DOM...

    JavaScript实现Ajax总结

    **总结** Ajax的核心在于XMLHttpRequest对象的使用,通过它与服务器进行异步通信。虽然存在一些缺点,但在优化用户体验方面,Ajax依然是Web开发中的重要技术。理解并掌握Ajax的工作原理和实现方式,对于构建交互性强...

    ajax应用个人总结

    Ajax(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使网页实现异步更新。在这个例子中,我们看到一个简单的Ajax应用,...

    ajax知识点总结

    **Ajax(Asynchronous JavaScript and XML)技术概述** Ajax是一种在无需刷新整个网页的情况下,能够更新部分网页内容的技术。它的核心是利用JavaScript与服务器进行异步数据交换,通过XML或者JSON等格式传输数据,...

    AJAX电子书(总结)

    **AJAX电子书总结** AJAX(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。这种技术的出现极大地提升了用户体验,因为它允许后台与服务器进行数据交换,而用户界面...

    Ajax课程总结

    ajax总结知识,大家一起共赏吧,很不错的,希望能给你帮助!

Global site tag (gtag.js) - Google Analytics