IT狗

Ajax与XMLHttpRequest随笔

1.XMLHttpRequest对象

  • 创建XHR对象:let xhr = new XMLHttpRequest();
  • open():启动一个请求准备发送

open()接收3个参数:请求类型('GET'、'POST')、请求的URL、是否异步发送请求(true or false)。

  • send():发送请求

    send()接受一个参数:作为请求主体要发送的数据,如果不需要发送数据,传入一个null, 以防止出现未知错误

  • setRequestHeader():设置自定义的请求头部信息

    setRequestHeader()接收两个参数:头部字段的名称和头部字段的值;调用此方法必须要在调用open()方法之后,send()之前。

  • getResponseHeader():获取响应信息中的某个指定头部信息

  • getAllResponseHeaders():获取响应信息的所有头部信息

    getResponseHeader()接收一个参数:需要知道的头部信息的名称;但W3C标准对这两个方法有限制,它们不能获取如Set-CookieSet-Cookie2等的头部信息;所以getAllResponseHeaders()只能拿到限制以外(即被视为safe)的头部信息,而不是全部;而调用getResponseHeader(string)方法时,传入的参数必须是限制以外的头部名称,否则会报错。

  • XHR对象属性:

    1. responseText:作为响应主体被返回的文本。

    2. responseXml:如果相应的内容类型为XML, 此属性保存响应数据的XML DOM文档; 如果为非XML数据,则为null。

    3. status: 响应的HTTP状态。

    4. statusText:HTTP的状态说明。

    5. readyState:表示请求/响应过程的阶段

      • 0:未初始化;未调用open()方法。

      • 1:启动;已调用open()方法,但未调用send()方法。

      • 2:发送;已调用send()方法,但未接收到响应。

      • 3:接收;已接收到部分响应数据。

      • 4:完成;已接收到所有响应数据。

        备注:readyState的值每改变一次,都会触发readystatechange事件。

  • XHR兼容性(2018-11 from www.caniuse.com

      XHR兼容性

2.创建具有兼容性的XMLHttpRequest对象

 1 function getXHR() { 2     let xhr = null; 3     if (window.XMLHttpRequest) { 4         //IE10+以及其他主流浏览器 5         xhr = new XMLHttpRequest(); 6          7     } else if (window.ActiveXObject) { 8         //IE9及以下、MSXML3、MSXML2.6及以下 9         let versions = [10             'MSXML2.XMLHttp.6.0', 11             'MSXML2.XMLHttp3.0', 12             'MSXML2.XMLHttp', 13             'Microsoft.XMLHttp'14         ];15         for (let i=0; i<versions.length; i++) {16             try {17                 //创建成功结束循环,创建失败抛出错误18                 xhr = new ActiveXObject(versions[i]);19                 break;20             } catch (e) {21                 //skip_跳过22             }23         }24         25     }26     return xhr;27 }

此文由 IT狗 编辑,本网站所发布展示的作品/文章版权归原作者所有,任何商业用途均须联系作者!

相关推荐

评论 暂无评论