Ajax 简介

Ajax 由 HTML、JavaScript™ 技术、DHTML 和 DOM 组成,这一杰出的方法可以将笨拙的 Web 界面转化成交互性的 Ajax 应用程序。它是一种构建网站的强大方法。

Ajax 尝试建立桌面应用程序的功能和交互性,与不断更新的 Web
应用程序之间的桥梁。可以使用像桌面应用程序中常见的动态用户界面和漂亮的控件,不过是在 Web 应用程序中。

Ajax 应用程序所用到的基本技术:

  1. HTML 用于建立 Web 表单并确定应用程序其他部分使用的字段。 • JavaScript 代码是运行 Ajax
  2. 应用程序的核心代码,帮助改进与服务器应用程序的通信。 • DHTML 或 Dynamic HTML,用于动态更新表单。我们将使用
  3. div、span 和其他动态 HTML 元素来标记 HTML。 • 文档对象模型 DOM 用于(通过 JavaScript 代码)处理
  4. HTML 结构和(某些情况下)服务器返回的 XML。

Ajax 的定义

Ajax= Asynchronous JavaScript and XML(以及 DHTML 等)Asynchronous异步JS和XML。

XMLHttpRequest这是一个 JavaScript 对象; 是处理所有服务器通信的对象,创建该对象很简单,如清单 1 所示。

清单 1. 创建新的 XMLHttpRequest 对象

<script language="javascript" type="text/javascript">var xmlHttp = new XMLHttpRequest();
</script>

通过 XMLHttpRequest 对象与服务器进行对话的是 JavaScript 技术。这不是一般的应用程序流,这恰恰是 Ajax的强大功能的来源。

Ajax 基本上就是把 JavaScript 技术和 XMLHttpRequest 对象放在 Web 表单和服务器之间。

得到 XMLHttpRequest 的句柄后,使用 JavaScript 代码完成以下任务:

  1. 获取表单数据:JavaScript 代码很容易从 HTML 表单中抽取数据并发送到服务器。
  2. 修改表单上的数据:更新表单也很简单,从设置字段值到迅速替换图像。
  3. 解析 HTML 和 XML:使用 JavaScript 代码操纵 DOM(请参阅 下一节),处理 HTML 表单服务器返回的 XML数据的结构。

对于前两点,需要非常熟悉 getElementById() 方法,如 清单 2 所示。

清单 2. 用 JavaScript 代码捕获和设置字段值

//捕获字段值:
// 获得字段"phone"的值并用其创建一个变量phone
var phone = document.getElementById("phone").value;
//设置字段值:
// 从response的数组中获得值并将其写到标签中
document.getElementById("order").value = response[0];
document.getElementById("address").value = response[1];

DOM的功能

当需要在 JavaScript 代码和服务器之间传递 XML 和改变 HTML 表单的时候,我们再深入研究 DOM。

获取 Request 对象

XMLHttpRequest 是 Ajax 应用程序的核心.

var xmlhttp;
if (window.XMLHttpRequest){// 从 IE7+, Firefox, Chrome, Opera, Safari 中获得XMLHttpRequest对象xmlhttp=new XMLHttpRequest();}
else{//从 IE6, IE5 中获得XMLHttpRequest对象xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");}

清单 4. 以支持多种浏览器的方式创建 XMLHttpRequest 对象

/* Create a new XMLHttpRequest object to talk to the Web server */
var xmlHttp = false;
/*@cc_on @*/
/*@if (@_jscript_version >= 5)
try {xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {try {xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");} catch (e2) {xmlHttp = false;}
}
@end @*/if (!xmlHttp &amp;& typeof XMLHttpRequest != 'undefined') {xmlHttp = new XMLHttpRequest();
}

这段代码的核心分为三步:

  1. 建立一个变量 xmlHttp 来引用即将创建的 XMLHttpRequest 对象。
  2. 尝试在 Microsoft 浏览器中创建该对象:
    1)尝试使用 Msxml2.XMLHTTP 对象创建它。
    2)如果失败,再尝试 Microsoft.XMLHTTP 对象。
  3. 如果仍然没有建立 xmlHttp,则以非 Microsoft 的方式创建该对象。 最后,xmlHttp 应该引用一个有效的XMLHttpRequest 对象,无论运行什么样的浏览器。

Ajax 的请求/响应

与服务器上的 Web 应用程序打交道的是 JavaScript 技术,而不是直接提交给那个应用程序的 HTML 表单。
发出请求
如何使用XMLHttpRequest 对象?
首先–需要一个能够调用JavaScript 方法 的Web 页面 。
接下来就是在所有 Ajax 应用程序中基本都雷同的流程:

1、从 Web 表单中获取需要的数据。
2、建立要连接的 URL。
3、打开到服务器的连接。
4、设置服务器在完成后要运行的函数。
5、发送请求。

清单 5 中的示例 Ajax 方法就是按照这个顺序组织的:

清单 5. 发出 Ajax 请求

function callServer() {// 获得city和state的值var city = document.getElementById("city").value;var state = document.getElementById("state").value;// 当它们的值任一个不存在的时候结束JSif ((city == null) || (city == "")) return;if ((state == null) || (state == "")) return;// 创建连接的URL对象var url = "/scripts/getZipCode.php?city=" + escape(city) + "&state=" + escape(state);// 打开一个连接服务器的连接xmlHttp.open("GET", url, true);// 设置一个方法,当请求返回的时候调用这个方法xmlHttp.onreadystatechange = updatePage;//xmlhttp.onreadystatechange=function()//{//    if (xmlhttp.readyState==4 && xmlhttp.status==200)//    {//   document.getElementById("myDiv").innerHTML=xmlhttp.responseText;//    }//}// 发生链接xmlHttp.send(null);
}

开始的代码使用基本 JavaScript 代码获取几个表单字段的值。 然后设置一个 PHP 脚本作为链接的目标。 要注意脚本 URL
的指定方式,city 和 state(来自表单)使用简单的 GET 参数附加在 URL 之后。 最后一个参数如果设为
true,那么将请求一个异步连接(这就是 Ajax 的由来)。 如果使用 false,那么代码发出请求后将等待服务器返回的响应。
如果设为 true,当服务器在后台处理请求的时候用户仍然可以使用表单(甚至调用其他 JavaScript 方法)。
onreadystatechange
属性可以告诉服务器在运行完成后做什么。因为代码没有等待服务器,必须让服务器知道怎么做以便您能作出响应。
在这个示例中,如果服务器处理完了请求,一个特殊的名为 updatePage() 的方法将被触发。
最后,使用值 null 调用send()。因为已经在请求 URL 中添加了要发送给服务器的数据(city 和state),所以请求中不需要发送任何数据。这样就发出了请求,服务器按照您的要求工作。

处理响应

1.什么也不要做,直到 xmlHttp.readyState 属性的值等于 4。
2.服务器将把响应填充到 xmlHttp.responseText 属性中。

其中的第一点,即就绪状态;
第二点,使用 xmlHttp.responseText 属性获得服务器的响应,清单 6中的示例方法可供服务器根据 清单 5 中发送的数据调用。

清单 6. 处理服务器响应

function updatePage() {if (xmlHttp.readyState == 4) {var response = xmlHttp.responseText;document.getElementById("zipCode").value = response;}
}

它等待服务器调用,如果是就绪状态,则使用服务器返回的值(这里是用户输入的城市和州的 ZIP 编码)设置另一个表单字段的值。
一旦服务器返回 ZIP 编码,updatePage() 方法就用城市/州的 ZIP 编码设置那个字段的值,用户就可以改写该值。这样做有两个原因:

保持例子简单,说明有时候可能希望用户能够修改服务器返回的数据。

要记住这两点,它们对于好的用户界面设计来说很重要。

连接 Web 表单

一个 JavaScript 方法捕捉用户输入表单的信息并将其发送到服务器,另一个 JavaScript 方法监听和处理响应,并在响应返回时设置字段的值。所有这些实际上都依赖于调用 第一个 JavaScript 方法,它启动了整个过程。
利用 JavaScript 技术更新表单。

清单 7. 启动一个 Ajax 过程

<form><p>City: <input type="text" name="city" id="city" size="25" onChange="callServer();" /></p><p>State: <input type="text" name="state" id="state" size="25" onChange="callServer();" /></p><p>Zip Code: <input type="text" name="zipCode" id="city" size="5" /></p>
</form>

当用户在 city 或 state 字段中输入新的值时,callServer() 方法就被触发,于是 Ajax 开始运行了。

结束语

在下一期文章中,您将掌握:

XMLHttpRequest 对象
学会如何处理 JavaScript 和服务器的通信
如何使用 HTML 表单以及如何获得 DOM 句柄。

Ajax 完整教程-(一)相关推荐

  1. Ajax 完整教程 (转)

    Ajax 完整教程 第 1 页 Ajax 简介 Ajax 由 HTML.JavaScript™ 技术.DHTML 和 DOM 组成,这一杰出的方法可以将笨拙的 Web 界面转化成交互性的 Ajax 应 ...

  2. Ajax 完整教程(转载)

    第 1 页 Ajax 简介 Ajax 由 HTML.JavaScript™ 技术.DHTML 和 DOM 组成,这一杰出的方法可以将笨拙的 Web 界面转化成交互性的 Ajax 应用程序.本文的作者是 ...

  3. Ajax 完整教程-(二)

    Web 2.0 一瞥 我们需要一种方法使 发送的请求 和 接收的响应 只包含需要的数据而不是整个 HTML 页面. 多数交互都是在已有页面上增加细节.修改主体文本或者覆盖原有数据.这些情况下,Ajax ...

  4. Ajax 完整教程-(三)

    原文地址: https://www.ibm.com/developerworks/cn/xml/wa-ajaxintro3/index.html 在本系列的 上篇文章 中,我们将详细介绍 XMLHtt ...

  5. jquery中ajax完整例子get,jq的ajax方法,jquery中ajax完整例子

    jq的ajax方法,jquery中ajax完整例子 相较与js异步对象的繁琐,jq的ajax对象结构更加清晰 一:ajax对象简述 ajax(Asynchronous JavaScript and X ...

  6. [转]AJAX基础教程

    AJAX基础教程 这篇文章将带您浏览整个AJAX的基本概貌,并展示两个简单的例子让您轻松上路. 什么是 AJAX? AJAX (异步 JavaScript 和 XML) 是个新产生的术语,专为描述Ja ...

  7. google地图api js调用完整教程(路径回放)

    google地图api js调用完整教程(路径回放) 1,申请一个Google map api得key 目前来看,Google key激活要绑定一些国际银行卡(比如万事达,visa) 申请key详细地 ...

  8. 【Dom4j】Dom4j完整教程详解

    Dom4j完整教程 目录 Dom4j完整教程 1.DOM4J简介 2.XML文档操作1 2.1.读取XML文档: 2.2.获取根节点 2.3.. 新增一个节点以及其下的子节点与数据 2.4. 写入XM ...

  9. 【★】KMP算法完整教程

    2019独角兽企业重金招聘Python工程师标准>>> KMP算法完整教程 全称:                               Knuth_Morris_Pratt ...

最新文章

  1. 20160722noip模拟赛alexandrali
  2. IaaS, PaaS和SaaS是云计算的三种服务模式
  3. Objective-C:三种文件导入的方式以及atomic和nonatomic的区别
  4. Windows10文件重命名/复制/移动时,导致文件资源管理器卡顿,解决方案
  5. python商品评论分析_NLP实战:用主题建模分析网购评论(附Python代码)
  6. ssrs筛选器_SSRS ReportServer:服务性能计数器指南
  7. 微信小程序开发资料汇总
  8. linux work有关的命令,Linux执行后台work相关
  9. python实现sm3算法
  10. php10充电宝拆解,【变废为宝拆解】拆解一个正品的小米移动电源10400mAh版
  11. php 威盾加密解密,解析php加密解密混淆的手段,如 phpjm,phpdp神盾,php威盾
  12. UI设计公司面试时会提哪些问题?
  13. 什么是 java 序列化?什么情况下需要序列化?
  14. C\C ++语言 文件备份实验
  15. firebox插件制作
  16. 100天精通Andriod逆向——第3天:真机环境配置
  17. 深度解读《关于防范NFT相关金融风险倡议》透露哪些监管信号与数字藏品新发展之路?
  18. 基于 ESO-PLL 的永磁同步电机无位置传感器控制
  19. 游戏设计自学记录(27)
  20. xampp+phpstorm使用xdebug

热门文章

  1. 线上前端静态资源代理到本地的几种方式
  2. Google、迅雷与李开复、周鸿祎的那点破事
  3. 旭日x3----ROS2-foxy版本 安装navigation2
  4. [转载] 杜拉拉升职记——37 整个我的人,整颗我的心
  5. Linux rz 上传文件失败
  6. DAY 7 | 自学前端第七天
  7. BAT产品经理面试题--如何同时拿下百度腾讯阿里的产品岗offer
  8. [单调栈/差分/尺取/单调队列]Exercise Week5 A最大矩形+B魔法猫+C平衡字符串+D滑动窗口
  9. 极路由3与存储的适配规划
  10. 从Lync2010看微软UC发展