zoukankan      html  css  js  c++  java
  • JavaScript基础笔记(十二)Ajax

    Ajax

    一、XMLHttpRequest对象

    一)XHR用法

        var xhr = new XMLHttpRequest();
        //open()方法,参数一:发送方法,参数二:请求的URL,参数三:是否发送异步请求
        //调用open()方法不会真正发送请求,只是启动一个请求以备发送。
        xhr.open('get', 'test.txt', false);
        //send()方法接受一个参数,即作为请求主体要发送的数据,如果无数据也要传入null
        xhr.send(null);
        //在收到请求后响应的数据会自动填充到XHR对象的属性中
        /*
        * 相关属性介绍如下:
        * 1)responseText:服务器返回的文本
        * 2)responseXML:响应的XML
        * 3)status:响应的状态,200表示成功,此时responseText和responseXML
        * 都可以访问了,304表示访问的资源没有被修改,可以使用直接使用浏览器缓存。
        * 4)statusText:状态的说明
        *
        * */

    当我们发送异步请求时可以检测xhr对象的readyState,以表示请求的状态属性其值可以是:

    1)0:尚未调用open()方法

    2)1:已经调用open()方法,但还没有调用send()方法

    3)2:已经调用send()方法,但还没有接收到响应

    4)3:已经接收到部分响应数据

    5)4:已经接收到全部响应数据

    readyState属性的值由一个变为另一个都会触发readystatechange事件。

    注意:必须在open()调用之前定义readystatechange事件处理程序才能确保跨浏览器兼容问题。

        var xhr = createXHR();
        xhr.onreadystatechange = function(){
            if (xhr.readyState == 4){
                if ((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304){
                    alert(xhr.responseText);
                } else {
                    alert("Request was unsuccessful: " + xhr.status);
                }
            }
        };
        xhr.open("get", "example.txt", true);
        xhr.send(null);

    这个例子在 onreadystatechange 事件处理程序中使用了 xhr 对象,没有使用
    this 对象,原因是 onreadystatechange 事件处理程序的作用域问题。如果使用
    this 对象,在有的浏览器中会导致函数执行失败,或者导致错误发生。因此,使用
    实际的 XHR 对象实例变量是较为可靠的一种方式。

    另外,在接收到响应之前还可以调用 abort()方法来取消异步请求,如下所示:
    xhr.abort();
    调用这个方法后, XHR 对象会停止触发事件,而且也不再允许访问任何与响应有关的对象属性。在
    终止请求之后,还应该对 XHR 对象进行解引用操作。由于内存原因,不建议重用 XHR 对象。

    二)HTTP头部信息

    Accept:浏览器能够处理的内容类型。
    Accept-Charset:浏览器能够显示的字符集。
    Accept-Encoding:浏览器能够处理的压缩编码。
    Accept-Language:浏览器当前设置的语言。
    Connection:浏览器与服务器之间连接的类型。
    Cookie:当前页面设置的任何 Cookie
    Host:发出请求的页面所在的域 。
    Referer:发出请求的页面的 URI。注意, HTTP 规范将这个头部字段拼写错了,而为保证与规
    范一致,也只能将错就错了。(这个英文单词的正确拼法应该是 referrer。)
    User-Agent:浏览器的用户代理字符串。

    1)setRequestHeader()方法可以设置自定义的请求头部信息。这个方法接受两个参数:头部字段
    的名称和头部字段的值。要成功发送请求头部信息,必须在调用 open()方法之后且调用 send()方法
    之前调用 setRequestHeader()

    2)getAllResponseHeaders()方法则可以取得一个包含所有头部信息的长字符串

    三)GET请求

    使用 GET 请求经常会发生的一个错误,就是查询字符串的格式有问题。查询字符串中每个参数的名
    称和值都必须使用 encodeURIComponent()进行编码,然后才能放到 URL 的末尾;而且所有名-值对
    儿都必须由和号(&)分隔

    四)POST请求

    默认情况下,服务器对 POST 请求和提交 Web 表单的请求并不会一视同仁。因此,服务器端必须有
    程序来读取发送过来的原始数据,并从中解析出有用的部分。不过,我们可以使用 XHR 来模仿表单提
    交:首先将 Content-Type 头部信息设置为 application/x-www-form-urlencoded,也就是表单
    提交时的内容类型,其次是以适当的格式创建一个字符串
    POST 数据的格式与查
    询字符串格式相同。如果需要将页面中表单的数据进行序列化,然后再通过 XHR 发送到服务器,那么
    就可以使用 serialize()函数来创建这个字符串

    xhr.open("post", "postexample.php", true);
    xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    var form = document.getElementById("user-info");
    xhr.send(serialize(form));

    二、XMLRequest 2级

    一)FormData

    FormData用于序列化表单以及创建与表单相同的格式的数据(用于通过XHR传输)

        var data = new FormData();
        //append(name, value)分别对应表单中的键和值
        data.append("name", "Jerry");
        var data2 = new FormData(document.forms[0]);
        //创建了formData后可以将他传给send()方法

    二)超时设定

    XHR的timeout属性,可以设置超时时间,请求在等待多少秒无响应后就终止。超时时会触发ontimeout事件。

    Simple is important!
  • 相关阅读:
    微服务实战系列(七)-网关springcloud gateway
    微服务实战系列(六)-网关springcloud zuul
    微服务实战系列(五)-注册中心Eureka与nacos区别
    微服务实战系列(四)-注册中心springcloud alibaba nacos
    中国唯一入选 Forrester 领导者象限,阿里云 Serverless 全球领先
    面对不可避免的故障,我们造了一个“上帝视角”的控制台
    实习就参与“服务过亿用户的项目”,是什么体验?
    Go Mysql Driver 集成 Seata-Golang 解决分布式事务问题
    云原生时代下,容器安全的“四个挑战”和“两个关键”
    OpenKruise v0.8.0 核心能力解读:管理 Sidecar 容器的利器
  • 原文地址:https://www.cnblogs.com/Shadowplay/p/8552779.html
Copyright © 2011-2022 走看看