1. 创建 XMLHttpRequest 对象的一个实例

var xmlHttp;
function createXMLHttpRequest() {//检查是否支持 ActiveXObject 控件(IE浏览器)if(window.ActiveXObject) {xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");} else if(window.XMLHttpRequest) {xmlHttp = new XMLHttpRequest(); }
}

2. 方法和属性

2.1 常用的方法有 open( ) 和 send( ) 。

void open(string method, string url, boolean async, string username, string password) 建立对服务器的调用。

  • method: GET、POST或PUT。
  • url:相对url或绝对url。
  • async:可选,默认值为true,表示异步请求;false表示同步。

void send(context):具体向服务器发出请求。如果请求声明为异步,这个方法就会立即返回,否则它会等待直到接收到响应为止。

  • 可选参数可以是 DOM 对象的实例、输入流、或者串。若请求类型为 GET 时,参数使用 null;若为 POST 时,参数内容将作为请求体的一部分发送。

void setRequestHeader(string header, string value):为请求中一个给定的首部设置值。这个方法必须在 open() 之后才能调用。

  • header:要设置的首部。
  • value: 在首部中放置的值。

void abort():停止请求。

string getAllResponseHeaders():返回一个串,其中包含HTTP请求的所有响应首部,首部包括Content-length、Data和URL。

string getResponseHeaders(string header):与上面的 getAllResponseHeaders( ) 对应。

  • header表示你希望得到的指定首部值,并且把这个值作为串返回。

2.2 标准 XMLHttpRequest 属性

属性 描述
onreadystatechange 每个状态改变时都会触发这个事件处理器,值可以为回调函数的指针
readyState 请求的状态。有5个可取值。(在下方有说明)
responseText 服务器的响应,表示一个串
responseXML 服务器的响应,表示为XML。这个对象可解析为一个 DOM 对象
status 服务器的 HTTP 状态码(200对应 OK,404对应 Not Found …)
statusText HTTP 状态码的相应文本(OK 或 Not Found …)

readyState 请求状态的5个值:

  • 0:未初始化
  • 1:正在加载
  • 2:已加载
  • 3:交互中
  • 4:完成

3. Ajax 交互示例

Created with Raphaël 2.1.0 用户界面 用户界面 ajax引擎(XmlHttpRequest) ajax引擎(XmlHttpRequest) Web服务器 Web服务器 js创建XHR对象实例 调用请求(open+send) 服务器响应,并触发回调函数 根据readyState和status返回数据

请求返回到浏览器时的首部设置:

  • Content-Type:text/html
  • Cache-Control:no-cache

4. GET 与 POST

GET 请求通过向 url 传递参数,浏览器和服务器会限制其长度。
POST 则不会限制发送给服务器的数据量大小。一般来讲,

  • 使用 GET 方法从服务器获取数据。
  • 使用 POST 方法改变服务器上的状态。

使用 POST 时,需要设置 XMLHttpRequest 对象的 Content-Type 首部:

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

5. 简单请求

5.1 回调

onreadystatechange 属性存储了回调函数的指针。当 XMLHttpRequest 对象的内部状态发生改变时,就会调用这个回调函数。当进行了异步调用,请求就会发出,脚本立即处理执行。一旦发出了请求,对象的 readyState 属性会经过几个变化,一般处理的是服务器响应结束时的状态。
回调函数 callback 方法:

xmlHttp.onreadystatechange = callback; //函数指针
function callback() {if(xmlHttp.readyState == 4) {if(xmlHttp.Status == 200) {//可以简单的设置div的文本等等}       }
}

5.2 简单请求的示例

//javascript
var xmlHttp;function createXMLHttpRequest() {//检查是否支持 ActiveXObject 控件(IE浏览器)if(window.ActiveXObject) {xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");} else if(window.XMLHttpRequest) {xmlHttp = new XMLHttpRequest(); }
}function startRequest() {createXMLHttpRequest();xmlHttp.onreadystatechange = handleStateChange;xmlHttp.open("GET", "simpleResponse.xml", true);xmlHttp.send(null);
}function handleStateChange() {if(xmlHttp.readyState == 4) {if(xmlHttp.status == 200) {alert("The server replied with: " + xmlHttp.responseText);//显示 simpleResponse.xml 里的文本}}
}
<!--html-->
<form action="#"><input type="button" value="Start Basic Asynchronous Request" onclick="startRequest();" />
</form>

注:以上摘自《Ajax基础教程》

Ajax基础教程【2】使用XMLHttpRequest对象相关推荐

  1. Ajax基础教程电子版

    Ajax基础教程电子版 添加时间:2006-4-26 19:32:07 软件图片: 授权形式:免费 适用平台:Win98/WinMe/WinNT/Win2000/WinXP 软件语言:简体中文 下载次 ...

  2. [转]AJAX基础教程

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

  3. 迅速成为炙手可热的新一代程序员看《Ajax基础教程》

      Ajax基础教程 Foundations of Ajax   | Ryan Asleson著 金灵译 人民邮电出版社  | 7-115-14481-8/TP·5211 | 2006-02-16 | ...

  4. javascript基础教程_JavaScript基础教程(九)对象、类的定义与使用

    对象.类的定义与使用 对象与类是面向对象程序设计语言教学过程中不可避免需要讲解的内容之一.很多人将两者混为一谈,简单认为对象就是类,类就是对象.实际上深入分析的话,对象与类的区别还是较为明显的.本文主 ...

  5. java ajax教程_Jquery ajax基础教程

    jQuery的Ajax带来了无需刷新的web页面革命.这里就详细介绍一下jQuery所涉及到的Ajax操作.(无需特殊说明,均需要有服务器配置,这里本人用的是Tomcat 7) 1.基于请求加载文件数 ...

  6. 《Ajax基础教程》读书笔记

    嗯,昨天看那个方案要学习这个,就准备刷这部书,争取国庆节把它刷完,嗯,但是还有一部分jQuery没有看完,想来时间是够用,加油吧生活,高兴是Y君私信我了,但是很没落的话,嗯,想起她写给我的句子:在高楼 ...

  7. python基础教程:对可变对象和不可变对象的详解

    数据类型分为可变.不可变.可变对象表示可以原处修改该数据对象,不可变对象表示必须创建新对象来保存修改后的数据. 在基础数据类型中: 数值.字符串.元组.frozenset是不可变对象 列表.set.d ...

  8. AJAX基础教程zz

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

  9. python基础教程: __del__() 清空对象

    python垃圾回收机制:当一个对象的引用被完全清空之后,就会调用__del__()方法来清空这个对象 当对象的引用没有被完全清空时,代码如下: class C():def __init__(self ...

最新文章

  1. [导入]Nhibernate引入自定义Membership和Role
  2. oracle双机切换 无法挂载,Linux下Oracle RAC一个节点宕机导致共享存储无法挂载的故障排除...
  3. 大学最重要的七项学习
  4. IOS开发-GitHub使用详解
  5. ElementUI中el-table双击单元格事件并获取指定列的值和弹窗显示详细信息
  6. 130道ASP.NET面试题
  7. 参数MEMORY_MAX_TARGET 和MEMORY_TARGET 的修改
  8. android studio on/off 切换开关,如何使用android studio中的开关小部件来启用/禁用函数()?...
  9. RT1021使用RTS引脚控制RS485芯片收发使能
  10. Linux的拓扑结构,linux底下的makefile框架拓扑结构分析
  11. android实现延时的方法,Android实现延时总结
  12. 转:成为Java高级程序员需要掌握哪些?
  13. 第四题:输入某年某月某日,判断这一天是这一年的第几天?
  14. appkey 即 paySignkey
  15. c++学习笔记-二进制文件操作(哔站-黑马程序员c++教学视频)
  16. 云笔记Leanote,超级好用的一款开源云笔记
  17. Android APP性能及专项测试(个人整理)
  18. Texlive和TeXStudio的下载安装
  19. socket编程---send函数recv函数详解
  20. 小白说js--我是一个逆袭的JS

热门文章

  1. OB0206 obsidian 表格编辑插件:advanced Tables插件使用
  2. 定时任务超时处理方法
  3. vue下拉框筛选表格数据
  4. 分享三款别致的原型设计图
  5. Vue.js+ECharts:堆叠柱状图
  6. Baeldung Java 周评 | 第一百零五弹(关键词:如果 Java 是今天设计的、内容丰富的 Spring 会议、JPA 测试用例模版、高性能 Java 持久化、自动化订购午餐、前端五强)
  7. EDUSOHO踩坑笔记之三十三:班级
  8. iOS over-the-air installation分发内部测试版本(浏览器安装ipa)
  9. 文件的打开(fopen)、读取和存储
  10. 真实经纬度(gps)转成百度坐标的js方法