`
传说の黄花菜
  • 浏览: 202221 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

ajax入门详解(一)

阅读更多

 

l 一个实例

在开始正式讲解 Ajax之前,首先让我们先来看看Google Map使用Ajax改善其产品设计的效果。

1.  在浏览器地址栏中输入http://maps.google.com打开Google Map的界面。

2.  在页面顶端的搜索框中输入“China”,单击“Search”按钮。

3.  单击地图右上角的“Satellite”按钮,切换到卫星界面。

4.  调整地图左上角的尺寸,方法或者缩小当前区域。可以看到,地图区域的图象根据标尺的位置快速的变换。

5.  按住鼠标左键,拖拽地图,地图区域的图象随着鼠标的移动而移动这个过程的图象是实时更新的。效果如下图所。



 

 

 

由上可以明显的看出,当用户拖动地图进行操作的时候,Web页上的地图立即发生相应的变化,页面却没有刷新,当按住鼠标左键移动地图的时候,地图跟着移动,这个过程是快速的,而期间用户没有想服务器提交表单或和单击一个超链接。如果用传统的Web应用程序交互思维来理解,这个过程是难以理解的,这正是Ajax的魅力。

l什么是Ajax?

在研究ajax之前首先让我们先来讨论一个问题 ——什么是Web 2.0 。听到 Web 2.0 这个词的时候,应该首先问一问 “Web 1.0 是什么?虽然很少听人提到 Web 1.0,实际上它指的就是具有完全不同的请求和响应模型的传统 Web。比如,到 hdu.edu.cn 网站上点击一个按钮。就会对服务器发送一个请求,然后响应再返回到浏览器。该请求不仅仅是新内容和项目列表,而是另一个完整的 HTML 页面。因此当 Web 浏览器用新的 HTML 页面重绘时,可能会看到闪烁或抖动。事实上,通过看到的每个新页面可以清晰地看到请求和响应。

  Web 2.0(在很大程度上)消除了这种看得见的往复交互。比如在 Google Maps 上,你可以拖动地图,放大和缩小,只有很少的重绘操作。当然这里仍然有请求和响应,只不过都藏到了幕后。作为用户,体验更加舒适,感觉很像桌面应用程序。这种新的感受和范型就是当有人提到 Web 2.0 时您所体会到的。

  需要关心的是如何使这些新的交互成为可能。显然,仍然需要发出请求和接收响应,但正是针对每次请求/响应交互的 HTML 重绘造成了缓慢、笨拙的 Web 交互的感受。因此很清楚,我们需要一种方法使发送的请求和接收的响应只 包含需要的数据而不是整个 HTML 页面。惟一需要获得整个新 HTML 页面的时候就是希望用户看到 新页面的时候。

  但多数交互都是在已有页面上增加细节、修改主体文本或者覆盖原有数据。这些情况下,Ajax Web 2.0 方法允许在不 更新整个 HTML 页面的情况下发送和接收数据。对于那些经常上网的人,这种能力可以让您的应用程序感觉更快、响应更及时,让他们不时地光顾您的网站。

 

因此在这里,我们是时候可以对ajax做出一个完整的解释了,Adaptive Path公司的Jesse James Garrett这样定义Ajax

  Ajax不是一种技术。实际上,它由几种蓬勃发展的技术以新的强大方式组合而成。Ajax包含:

  • 基于XHTMLCSS标准的表示;
  • 使用Document Object Model进行动态显示和交互;
  • 使用XMLHttpRequest与服务器进行异步通信;
  • 使用JavaScript绑定一切。

这非常好,但为什么要以Ajax命名呢?其实术语Ajax是由Jesse James Garrett创造的,他说它是“Asynchronous JavaScript + XML的简写

l      Ajax工作原理

通过上述的定义,我们应该已经知道Ajax的组成了,即他是由XHTMLXMLCSSDOMXMLHttpRequest,JavaScript等技术综合而成的,然而,真正使用Ajax能实现异步通信,要真正实现这种绚丽的奇迹,必须非常熟悉一个JavaScript 对象,即 XMLHttpRequest。因此我们要了解Ajax的工作原理,就要从理解XMLHttpRequest这个对象开始。

下面给出将要用于该对象的很少的几个 方法和属性。

  ·open():建立到服务器的新请求。

     ·send():向服务器发送请求。

     ·abort():退出当前请求。

  
  ·readyState:提供当前 HTML 的就绪状态。

  
  ·responseText:服务器返回的请求响应文本。

‘onreadystatechange:回调方法

 ·responseXML:服务器返回的请求响应XML形式组织的文本。

  下面我们简单的介绍一下这几个方法的作用。

l         创建一个XMLHttpRequest

     首先需要创建一个新变量并赋给它一个 XMLHttpRequest 对象实例。这在 JavaScript 中很简单,只要对该对象名使用 new 关键字即可,如下代码所示。

script language="javascript" type="text/javascript"
 var request = new XMLHttpRequest();
/script
  在 JavaScript 中用 var 创建一个变量,给它一个名字(如 “request”),然后赋给它一个新的 XMLHttpRequest 实例。此后就可以在函数中使用该对象了。
  错误处理
  在实际上各种事情都可能出错,而上面的代码没有提供任何错误处理。较好的办法是创建该对象,并在出现问题时优雅地退出。比如,任何较早的浏览器都不支持 XMLHttpRequest,您需要让这些用户知道有些地方出了问题。下面js代码通过创建getXMLHttpRequest()方法说明如何创建该对象。

代码1:一个详细的XMLHttpRequest对象的创建

script language="javascript" type="text/javascript"

function getXMLHttpRequest(){
 var request = false;
 try {

 request = new XMLHttpRequest();
 } catch (trymicrosoft) {
  try {
   request = new ActiveXObject("Msxml2.XMLHTTP");
  } catch (othermicrosoft) {
   try {
    request = new ActiveXObject("Microsoft.XMLHTTP");
   } catch (failed) {
    request = false;
   }
  }
 }
 return request;

}
/script
  一定要理解这些步骤:
  创建一个新变量 request 并赋值 false。后面将使用 false 作为判定条件,它表示还没有创建 XMLHttpRequest 对象。
  ·增加 try/catch 块:
  ·尝试创建 XMLHttpRequest 对象。
    1、如果失败(catch (failed))则保证 request 的值仍然为 false
    2、检查 request 是否仍为 false(如果一切正常就不会是 false)。
  ·如果出现问题则request 返回 false

此外,在上面的代码中,我们是不是注意到了一个问题,就是当request = new XMLHttpRequest();出现异常的时候,在catch语句中我们用了request = new ActiveXObject("Msxml2.XMLHTTP");request = new ActiveXObject("Microsoft.XMLHTTP");等语句进行对象获取,这是针对IE浏览器而进行的操作,因为IE浏览器对 XMLHttpRequest 版本有不同的称呼。事实上,它将其称为几种 不同的东西。如果使用较新版本的 Internet Explorer,则需要使用对象 Msxml2.XMLHTTP,而较老版本的 Internet Explorer 则使用 Microsoft.XMLHTTP。我们需要支持这两种对象类型(同时还要支持非 Microsoft 浏览器)。

l         XMLHttpRequest 发送请求
  得到请求对象之后就可以进入请求/响应循环了。记住,XMLHttpRequest 惟一的目的是让您发送请求和接收响应。其他一切都是 JavaScriptCSS 或页面中其他代码的工作:改变用户界面、切换图像、解释服务器返回的数据。准备好 XMLHttpRequest 之后,就可以向服务器发送请求了。
  Ajax 采用一种沙箱安全模型。因此,Ajax 代码(具体来说就是 XMLHttpRequest 对象)只能对所在的同一个域发送请求。如果让 Ajax 代码在www.hdu.edu.cn 上运行,则必须 www.hdu.edu.cn 中运行的脚本发送请求。
  设置服务器 URL
  首先要确定连接的服务器的 URL。这并不是 Ajax 的特殊要求,但仍然是建立连接所必需的。多数应用程序中都会结合一些静态数据和用户处理的表单中的数据来构造该 URL。比如,下列 JavaScript 代码获取电话号码字段的值并用其构造 URL

代码2: 建立请求 URL

script language="javascript" type="text/javascript"
function getCustomerInfo() {
 var phone = document.getElementById("phone").value;
 var url = "/cgi-local/lookupCustomer.jsp?phone=" + escape(phone);
}
/script
  首先,代码创建了一个新变量 phone,并把 ID “phone” 的表单字段的值赋给它。下列代码展示了这个表单的 XHTML,其中可以看到 phone 字段及其 id 属性。   

代码3 Break Neck Pizza 表单

body
 <form action="POST"
  <pEnter your phone number:
   <input type="text" size="14" name="phone" id="phone" onChange="getCustomerInfo();" /
  </p
  <pYour order will be delivered to:/p
  <div id="address"></div
  <pType your order in here:/p
  <p><textarea name="order" rows="6" cols="50" id="order"></textarea></p
  <p><input type="submit" value="Order Pizza" id="submit" /></p
 </form
/body
  还要注意,当用户输入电话号码或者改变电话号码时,将触发getCustomerInfo() 方法。该方法取得电话号码并构造存储在 url 变量中的 URL 字符串。由于 Ajax 代码是沙箱型的,因而只能连接到同一个域,实际上 URL 中不需要域名。该例中的脚本名为 /cgi-local/lookupCustomer.jsp。最后,电话号码作为 GET 参数附加到该脚本中:"phone=" + escape(phone)。 
  

  • 大小: 79.3 KB
分享到:
评论
22 楼 杨春超 2011-03-28  
ajax却是还用啊
21 楼 玲cc 2011-03-23  
有没有那种详细介绍ajax底层技术实现的文章?求推荐~~
20 楼 shichuanliujie 2011-03-14  
做小白鼠,也要做幸福的小白鼠,(⊙o⊙)
19 楼 yiyi_2 2011-03-11  
- -||,我ajax基本上只会用dwr,是不是太菜了
18 楼 hai_lei 2011-02-17  
写的易懂,挺你
17 楼 舞指如歌 2010-04-20  
明天要学,刚好看看
16 楼 lucky16 2010-04-12  
传说の黄花菜 写道
lucky16 写道
POST 和 GET 提交方式 , 代码书写方式有很大的不同吗?
两者又有好大的区别呢?


恩,两者还是有很多不同点的,我在这篇文章---POST方式发送ajax请求详解 http://04101334.iteye.com/blog/637695 中对此做了比较,有兴趣的话可以去看下:)

好的,谢谢,我现在项目中就是使用的原生JS来做的ajax,基本上我都是使用的GET。仔细看看,冲一下电,这方面比较欠缺!
15 楼 Frankinca 2010-04-12  
写的不错,收藏一下,以后项目组培训时用上咯
14 楼 passionke 2010-04-08  
为了杭电 顶你
13 楼 传说の黄花菜 2010-04-08  
chbest 写道
用框架做吧.不要用原生的

  确实 在实际开发中, 原生代码去开发几乎不切实际,本人一直也是采用prototype进行开发的,偶尔也用jquery,不过这篇文章主要是带新手们进入这个门槛,所以如果直接上框架就起不到入门这个效果了。。
12 楼 传说の黄花菜 2010-04-08  
lucky16 写道
POST 和 GET 提交方式 , 代码书写方式有很大的不同吗?
两者又有好大的区别呢?


恩,两者还是有很多不同点的,我在这篇文章---POST方式发送ajax请求详解 http://04101334.iteye.com/blog/637695 中对此做了比较,有兴趣的话可以去看下:)
11 楼 lucky16 2010-04-08  
POST 和 GET 提交方式 , 代码书写方式有很大的不同吗?
两者又有好大的区别呢?
10 楼 longxiaoyan 2010-04-08  
写得挺好的。
9 楼 传说の黄花菜 2010-04-08  
86asm 写道
   写得不错,支持下。  
ajax get方式提交,楼主能否给一份post的提交方案,我试过网上很多代码都不行。



http://04101334.iteye.com/blog/637695

刚写的这篇就是详细介绍如何使用post方式发送ajax的,希望对您有所帮助
8 楼 juliankim 2010-04-07  
下一篇应该会讲post的了吧,这个用的更多点
7 楼 chbest 2010-04-07  
用框架做吧.不要用原生的
6 楼 七月十五 2010-04-06  
satanest 写道
最近JE上好像很多这类将基础的文章。

貌似js要爆发……期待……
5 楼 wz_boy 2010-04-06  
期待2】
4 楼 wz_boy 2010-04-06  
meiowei 写道
都是一些要发布新书的牛人先给我们预览一下的   不过这个小白鼠  我愿意

我也愿意、
3 楼 meiowei 2010-04-06  
都是一些要发布新书的牛人先给我们预览一下的   不过这个小白鼠  我愿意

相关推荐

    ajax经典入门详解

    **Ajax经典入门详解** Ajax(Asynchronous JavaScript and XML)是一种创建动态网页的技术,它使得网页可以在不重新加载整个页面的情况下与服务器交换数据并更新部分网页内容。Ajax的核心是利用JavaScript和...

    ajax入门详解资料

    **Ajax 入门详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。这种技术的出现极大地提升了用户体验,因为它允许网页在后台与服务器进行数据交换,而...

    asp.net ajax入门与案例详解

    ASP.NET AJAX(Asynchronous JavaScript and XML)是一种微软提供的技术,用于构建富客户端Web应用程序,它允许部分页面更新,提供更好的用户体验,而无需整个页面刷新。本教程将带你深入理解ASP.NET AJAX的基础,并...

    ASP.NET AJAX入门与案例详解 Part 2

    本书介绍了ASP.NETAJAX框架的基础知识,包括AJAX的入门知识、JavaSeript和CSS等,重点介绍了ASP.NETAJAX的各控件以及ASP.NETAJAX控件工具箱的使用方法,并以作者开发的博客和BBS系统两个完整的案例,详细介绍了...

    Ajax经典入门案例详解(入门中的经典,经典中的入门,适合初学者)

    **Ajax经典入门案例详解** Ajax,全称异步JavaScript和XML,是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使网页实现异步更新,提升了用户体验。在Web...

    ajax简介及入门基础

    Ajax,全称为"Asynchronous JavaScript and XML",是一种在无需刷新整个网页的情况下,能够更新部分网页内容的技术。它并不是一项全新的技术,而是由一系列成熟的技术组合而成,包括JavaScript、DOM(Document ...

    ASP.NET AJAX 入门与案例详解

    本书《ASP.NET AJAX 入门与案例详解》是针对初学者和有一定基础的开发者设计的,旨在帮助读者快速掌握这一技术。 首先,ASP.NET AJAX的核心组件包括AJAX Control Toolkit、UpdatePanel、ScriptManager和Web ...

    ajax_入门实例_

    **Ajax 入门实例详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。这种技术的核心在于利用JavaScript创建XMLHttpRequest对象,通过这个对象与服务器...

    ASP.NET 2.0 AJAX入门经典实例,有很好的参考价值,XML-Script

    《ASP.NET 2.0 AJAX入门经典》这本书很可能包含了多个示例,演示如何使用AJAX技术来增强ASP.NET 2.0应用程序的交互性。这些实例可能涵盖用户界面改进、数据异步加载、实时验证等多个场景,帮助读者掌握实际开发技巧...

    AJAX入门

    ### AJAX入门知识点详解 #### 一、引言 AJAX(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换来实现这一点,从而为用户...

    Ajax入门与案例详解 也是我在网上看到的

    **Ajax入门与案例详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。这种技术的出现极大地提升了用户体验,因为它允许网页在后台与服务器进行数据...

    达内培训集团的CTO写的 ajax详解 适合入门学习的

    达内培训集团的CTO写的 ajax详解 适合入门学习的

    ASP.NET AJAX入门与案例详解 Part 1

    本书介绍了ASP.NETAJAX框架的基础知识,包括AJAX的入门知识、JavaSeript和CSS等,重点介绍了ASP.NETAJAX的各控件以及ASP.NETAJAX控件工具箱的使用方法,并以作者开发的博客和BBS系统两个完整的案例,详细介绍了...

    ajax入门视频教程

    **Ajax入门视频教程详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。这种技术使得Web应用程序能够更快、更高效地运行,提升了用户体验,因为它允许...

    经典AJAX简单入门篇(PDF+源码)

    这个经典AJAX简单入门篇包含了DOM(Document Object Model)的详解,是初学者掌握AJAX技术的重要资源。 **一、AJAX基本概念** AJAX的核心是通过XMLHttpRequest对象来与服务器进行异步数据交换,它允许网页在不重新...

    Ajax详解入门最新教程

    Ajax,即Asynchronous JavaScript and XML,是一种用于创建交互式网页应用的技术,允许页面在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页内容。它显著提升了用户体验,减少了网络延迟带来的等待...

    AJAX入门提高资料!

    **Ajax入门提高资料详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。这种技术的运用极大地提升了用户体验,因为它允许网页在后台与服务器进行数据...

    ajax入门实例|ajax注册实例

    **Ajax入门实例——用户注册详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使网页实现异步更新,大大...

    Ajax入门(读书笔记)

    ### Ajax入门知识点详解 #### 一、Ajax概述 **1.1 Ajax给Web应用带来的作用** - **桌面客户端化:** Ajax技术使得Web应用具备类似桌面客户端软件的灵活性,实现了加载动态化和操作客户端化,极大地提高了用户体验...

Global site tag (gtag.js) - Google Analytics