Ajax的实现 和 readState状态

ajax的实现

var getXmlHttpRequest = function () {
  if (window.XMLHttpRequest) {
    //主流浏览器提供了XMLHttpRequest对象
    return new XMLHttpRequest();
  }
  else if (window.ActiveXObject) {
    //低版本的IE浏览器没有提供XMLHttpRequest对象
    //所以必须使用IE浏览器的特定实现ActiveXObject
    return new ActiveXObject("Microsoft.XMLHTTP");
  }
};
var xhr = getXmlHttpRequest();
xhr.onreadystatechange = function () {
  if (xhr.readyState === 4 && xhr.status === 200) {
    //获取成功后执行操作
    //数据在xhr.responseText
  }
};
xhr.open("TYPE", "URL", true); //get/post  url  boolean表示是否使用异步
xhr.send(""); // get-> send(null)  post-> send(data)

readyState的五种状态

  1. 请求尚未初始化, 已经创建了一个XMLHttpRequest对象
  2. 服务器链接已经建立, 已经调用了XMLHttpRequest对象的open方法,并且XMLHttpRequest对象已经准备好将一个请求发送到服务器端
  3. 请求已经发送, 已经通过send方法把一个请求发送到服务器端,但是还没有收到一个响应
  4. 请求处理中, 已经接收到HTTP响应头部信息,但是消息体部分还没有完全接收到
  5. 请求完成, 且响应已经就绪

status状态吗

status是XMLHttpRequest对象的一个属性,表示响应的HTTP状态码。

在HTTP1.1协议下,HTTP状态码总共可分为5大类,如下表所示:

  1. 1XX 服务器收到请求,需要继续处理。例如101状态码,表示服务器将通知客户端使用更高版本的HTTP协议。

  2. 2XX 请求成功。例如200状态码,表示请求所希望的响应头或数据体将随此响应返回。

  3. 3XX 重定向。例如302状态码,表示临时重定向,请求将包含一个新的URL地址,客户端将对新的地址进行GET请求。

  4. 4XX 客户端错误。例如404状态码,表示客户端请求的资源不存在。

  5. 5XX 服务器错误。例如500状态码,表示服务器遇到了一个未曾预料的情况,导致了它无法完成响应,一般来说,这个问题会在程序代码出错时出现。

你可能感兴趣的:(Ajax的实现 和 readState状态)