AJAX XMLHttpRequest对象

 
XMLHttpRequest 对象用于与服务器交换数据,能够在不重新加载整个网页(刷新)的情况下,对网页进行部分更新。

XMLHttpRequest 对象是 AJAX 的基础,讲 AJAX ,大部分是在讲 XMLHttpRequest 对象。

所有现代浏览器(IE 7.0+、Chrome、FireFox、Opera、Safari)均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)。

XMLHttpRequest 对象还没有标准化,但是 W3C 已经开始了标准化的工作,讲解的内容都是基于标准化的工作草案。

对于较新的浏览器,创建 XMLHttpRequest 对象的语法:

  1. var xmlhttp=newXMLHttpRequest();
 

对于比较老的IE浏览器(IE5 和 IE6),使用 ActiveX 来创建:

  1. var xmlhttp=newActiveXObject("Microsoft.XMLHTTP");
 

兼容所有浏览器的创建 XMLHttpRequest 对象的代码:

  1. <script type="text/javascript">
  2. var xmlhttp;
  3. if(window.XMLHttpRequest){
  4. // code for IE7+, Firefox, Chrome, Opera, Safari
  5. xmlhttp=newXMLHttpRequest();
  6. }else{
  7. // code for IE6, IE5
  8. xmlhttp=newActiveXObject("Microsoft.XMLHTTP");
  9. }
  10. </script>
 

如果担心浏览器出现错误提示,请用 try..catch 代替 if...else ,如下所示:

  1. <script type="text/javascript">
  2. var xmlhttp;
  3. try{
  4. // code for IE7+, Firefox, Chrome, Opera, Safari
  5. xmlhttp=newXMLHttpRequest();
  6. }catch(e){
  7. // code for IE6, IE5
  8. xmlhttp=newActiveXObject("Microsoft.XMLHTTP");
  9. }
  10. </script>
 

XMLHttpRequest 对象有多个属性和方法,还有一个事件句柄。

XMLHttpRequest 对象属性和方法
属性 说明
readyState HTTP 请求的状态。当一个 XMLHttpRequest 初次创建时,这个属性的值从 0 开始,直到接收到完整的 HTTP 响应,这个值增加到 4。
responseText 从服务器接收到的数据(不包括头部)(解析为一个字符串)。
responseXML 从服务器接收到的数据(不包括头部)(解析为 XML 并作为 Document 对象返回)。
status 由服务器返回的 HTTP 状态代码。如 200 表示成功, 404 表示 "Not Found" 错误。
statusText 这个属性用名称而不是数字指定了请求的 HTTP 的状态代码。也就是说,当状态为 200 的时候它是 "OK",当状态为 404 的时候它是 "Not Found"。
事件句柄 说明
onreadystatechange 每次 readyState 属性改变的时候调用的事件句柄函数。
方法 说明
abort() 取消当前响应,关闭连接并且结束任何未完成的网络活动。
getAllResponseHeaders() 把 HTTP 响应头部(所有头部)作为一个字符串返回。
getResponseHeader() 返回指定的 HTTP 响应头部的值,其参数是要返回的 HTTP 响应头部的名称。可以使用任何大小写来制定这个头部名字,和响应头部的比较是不区分大小写的。
open() 初始化 HTTP 请求参数,例如 URL 和 HTTP 方法,但是并不发送请求。
send() 发送 HTTP 请求,使用传递给 open() 方法的参数,以及传递给该方法的可选请求体。
setRequestHeader() 向一个打开但未发送的请求设置或添加一个 HTTP 请求。

  1. var xhr =new XMLHttpRequest();
  2. console.log(xhr);
浏览器:(如果不记得属性和方法了,可以直接在浏览器查看)
 
 

参考:

互联网。
 
 
 

最新文章

  1. HTTP的长连接和短连接——Node上的测试
  2. MBTI-性格测试
  3. php 无法连接mysql
  4. Android 学习手札(备注)
  5. Frame Stacking
  6. java 解析国密SM2算法证书
  7. iptables原理详解以及功能说明
  8. 二部图(二分图判定--dfs)
  9. c/c++再学习:查找算法了解
  10. [Swift]LeetCode216. 组合总和 III | Combination Sum III
  11. Flow 常用知识点整理
  12. 数学运算比IF要快
  13. 获取访问IP
  14. ansible自动化运维详细教程及playbook详解
  15. FJUT3565 最大公约数之和(容斥)题解
  16. Oracle 存储过程A
  17. [java之设计模式]策略模式
  18. [COGS2426][HZOI 2016]几何
  19. Mysql解压版配置环境等
  20. 为什么有时候binlog文件会很大于max_binlog_size以及max_binlog_cache_size

热门文章

  1. 【小程序】基于.NET CORE2.1 的 微信开放平台 第三方平台开发 教程一 准备工作
  2. (七)Mybatis总结之注解开发
  3. [BZOJ2002][Hnoi2010]Bounce弹飞绵羊 LCT
  4. centOS linux 下nginx编译安装详解
  5. 大写URL转小写
  6. 【分享】iTOP-iMX6UL开发板驱动看门狗 watchdog 以及 Linux-c 测试例程
  7. (转)淘淘商城系列——MyBatis分页插件(PageHelper)的使用以及商品列表展示
  8. (function(){})() 立即执行函数
  9. xxtea 文件加密与解密
  10. CE工具里自带的学习工具--第一关