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 对象

    var xmlHttp = new XMLHttpRequest();

登录后复制

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

Ajax.png

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

Ajax1.png

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

1、获取表单数据:JavaScript 代码很容易从 HTML 表单中抽取数据并发送到服务器。

2、修改表单上的数据:更新表单也很简单,从设置字段值到迅速替换图像。

3、解析 HTML 和 XML:使用 JavaScript 代码操纵 DOM(请参阅 下一节),处理 HTML 表单服务器返回的 XML数据的结构

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

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

//捕获字段值:// 获得字段"phone"的值并用其创建一个变量phonevar 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 过程


登录后复制

结束语

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

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

更多相关问题请访问PHP中文网:Ajax视频教程

本文系列文章:

Ajax完整详细教程(二)

Ajax完整详细教程(三)

以上就是Ajax完整详细教程(一)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2729896.html

(0)
上一篇 2025年3月8日 00:11:02
下一篇 2025年3月8日 00:11:15

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Ajax完整详细教程(三)

    在本系列的 上篇文章 中,我们将详细介绍 xmlhttprequest 对象,它是 ajax 应用程序的中心,负责处理服务器端应用程序和脚本的请求,并处理从服务器端组件返回的数据。由于所有的 ajax 应用程序都要使用xmlhttprequ…

    2025年3月8日 编程技术
    200
  • ajax请求的五个步骤

    ajax请求的五个步骤     第一步,创建XMLHttpRequest对象 第二步,注册回调函数 第三步,配置请求信息,open(),get 第四步,发送请求,post请求下,要传递的参数放这 第五步,创建回调函数 //第一步,创建XML…

    2025年3月8日
    200
  • ajax获取网页添加到div中的方法

    ajax获取网页添加到div中的方法 1:利用DOM获取该 div 的 ID,然后清空该DIV的内容(如果你需要接着里面的内容添加可不要清空);需要注意点是清空最好用“ empty()  ”; 2: 把  async设成true ,否则又一…

    2025年3月8日
    200
  • 原生JS封装AJAX方法

    ajax大家每天都在用,jquery库对ajax的封装也很完善、很好用,下面我们看一下它的内部原理,并手动封装一个自己的ajax库。 一、原理 原生Ajax的发送需要四步: 1) 创建Ajax对象: XMLHttpRequest 2) 设置…

    编程技术 2025年3月7日
    200
  • ajax请求方式有几种

    1、$.ajax()返回其创建的 xmlhttprequest 对象 $.ajax() 只有一个参数:参数key/value对象,包含各配置及回调函数信息。 如果你指定了dataType选项,那么需要保证服务器返回正确的MIME信息,(如 …

    2025年3月7日
    200
  • Ajax 是干嘛用的?

    Ajax 是干嘛用的? Ajax是指一种创建交互式、快速动态网页应用的网页开发技术,无需重新加载整个网页的情况下,能够更新部分网页的技术,并且可以通过在后台与服务器进行少量数据交换,可以使网页实现异步更新。 Ajax 有缺点 使用Ajax的…

    2025年3月7日
    200
  • Ajax接收JSON数据

    1.   Ajax接收JSON数据 json:javascript对象表示法(javascript object notation)。json是一种存储和交换文本信息的语法。因为json比xml更轻量,效率更高,更易解析,所以在ajax中前…

    2025年3月7日
    200
  • 如何实现AJAX请求?

    如何实现ajax请求? 1、创建XMLHttpRequest实例; var xhr;if(window.XMLHttpRequest) {  //ie7+,firefox,chrome,safari,opera  xhr = new XML…

    2025年3月7日
    200
  • 深入了解ajax(图文详解)

    1.1 什么是ajax: Ajax即“Asynchronous Javascript And XML”(异步JavaScript 和XML),是指一种创建交互式网页应用的网页开发技术。Ajax=异步JavaScript和XML(标准通用标记…

    2025年3月7日 编程技术
    200
  • ajax实现excel报表导出的详解

    利用ajax实现excel报表导出【解决乱码问题】,供大家参考,具体内容如下 背景 项目中遇到一个场景,要导出一个excel报表。由于需要token验证,所以不能用a标签;由于页面复杂,所以不能使用表单提交。初步考虑前端使用ajax,后端返…

    2025年3月7日
    200

发表回复

登录后才能评论