欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ajax怎么使用,ajax的详细使用步骤

程序员文章站 2023-12-10 16:24:52
ajax 简介ajax 由 html、javascript™ 技术、dhtml 和 dom 组成,这一杰出的方法可以将笨拙的 web 界面转化成交互性的 ajax 应用程序。它是一种构建网站的强大方法...

ajax 简介

ajax 由 html、javascript™ 技术、dhtml 和 dom 组成,这一杰出的方法可以将笨拙的 web 界面转化成交互性的 ajax 应用程序。它是一种构建网站的强大方法。

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

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

1、html 用于建立 web 表单并确定应用程序其他部分使用的字段。

2、javascript 代码是运行 ajax应用程序的核心代码,帮助改进与服务器应用程序的通信。

3、dhtml 或 dynamic html,用于动态更新表单。我们将使用div、span 和其他动态 html 元素来标记 html。

4、文档对象模型 dom 用于(通过 javascript 代码)处理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怎么使用,ajax的详细使用步骤

ajax 基本上就是把 javascript 技术和 xmlhttprequest 对象放在 web 表单和服务器之间。

ajax怎么使用,ajax的详细使用步骤

得到 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 && typeof xmlhttprequest != ‘undefined’) {

xmlhttp = new xmlhttprequest();

}

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

1、建立一个变量 xmlhttp 来引用即将创建的 xmlhttprequest 对象。

2、尝试在 microsoft 浏览器中创建该对象:

1)尝试使用 msxml2.xmlhttp 对象创建它。

如果失败,再尝试 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;

// 当它们的值任一个不存在的时候结束js

if ((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>