美文网首页
ajax原理

ajax原理

作者: 古城凌三少 | 来源:发表于2019-05-30 22:36 被阅读0次

    Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面。这其中最关键的一步就是从服务器获得请求数据。

    XMLHttpRequest 对象提供了对 HTTP 协议的完全的访问,包括做出 POST 和 HEAD 请求以及普通的 GET 请求的能力。XMLHttpRequest 可以同步或异步地返回 Web 服务器的响应,并且能够以文本或者一个 DOM 文档的形式返回内容。

    尽管名为 XMLHttpRequest,它并不限于和 XML 文档一起使用:它可以接收任何形式的文本文档。

    XMLHttpRequest 对象是名为 AJAX的 Web 应用程序架构的一项关键功能。

    ajax原理 ajax原理

    get

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>

    <html>

    <head>

        <title>$Title$</title>

        <script type="text/javascript">

            //创建XMLHttpRequest对象

            function CreateXmlHttp() {

                var xmlhttp;

                if (window.XMLHttpRequest) {

                    //  IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码

                    xmlhttp = new XMLHttpRequest();

                }

                else {

                    // IE6, IE5 浏览器执行代码

                    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

                }

                return xmlhttp;

            }

            //执行get请求

            function getAjax03() {

                //1. 创建xmlhttprequest 对象

                var request = ajaxFunction();

                //2. 发送请求  注意url路径可以为相对路径或绝对路径

                request.open("GET", "demo?name='张三'&age=22", true);

                //3. 获取响应数据 注册监听的意思。  一会准备的状态发生了改变,那么就执行 = 号右边的方法

                request.onreadystatechange = function () {

                    //前半段表示 已经能够正常处理。再判断状态码是否是200

                    if (request.readyState == 4 && request.status == 200) {

                        //弹出响应的信息

                        alert(request.responseText);

                    }

                }

                request.send();

            }

        </script>

    </head>

    <body>

    <h1><a href="" onclick="getAjax03()">使用ajax方式发送get请求并传递参数然后获取返回值</a></h1>

    </body>

    </html>

    post

    <html>

    <head>

    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

    <title>Insert title here</title>

    <script type="text/javascript">

      //创建XMLHttpRequest对象

            function CreateXmlHttp() {

                var xmlhttp;

                if (window.XMLHttpRequest) {

                    //  IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码

                    xmlhttp = new XMLHttpRequest();

                }

                else {

                    // IE6, IE5 浏览器执行代码

                    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

                }

                return xmlhttp;

            }

    function post() {

    //1. 创建对象

    var request = ajaxFunction();

    //2. 发送请求

    request.open( "POST", "demo", true);

    //想获取服务器传送过来的数据, 加一个状态的监听。

    request.onreadystatechange=function(){

    if(request.readyState==4 && request.status == 200){

    alert("post:"+request.responseText);

    }

    }

    //如果使用的是post方式带数据,那么 这里要添加头, 说明提交的数据类型是一个经过url编码的form表单数据

    request.setRequestHeader("Content-type","application/x-www-form-urlencoded");

    //带数据过去  , 在send方法里面写表单数据。

    request.send("name='王五'&age=19");

    }

    </script>

    </head>

    <body>

    <h3><a href="" onclick="post()">使用Ajax方式发送Post请求</a></h3>

    </body>

    </html>

    注释

    open(method, url, async) 方法需要三个参数:

      method:发送请求所使用的方法(GET或POST);与POST相比,GET更简单也更快,并且在大部分情况下都能用;然而,在以下情况中,请使用POST请求:

    无法使用缓存文件(更新服务器上的文件或数据库)

    向服务器发送大量数据(POST 没有数据量限制)

    发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

     url:规定服务器端脚本的 URL(该文件可以是任何类型的文件,比如 .txt 和 .xml,或者服务器脚本文件,比如 .asp 和 .php (在传回响应之前,能够在服务器上执行任务));

     async:规定应当对请求进行异步(true)或同步(false)处理;true是在等待服务器响应时执行其他脚本,当响应就绪后对响应进行处理;false是等待服务器响应再执行。

    2. send() 方法可将请求送往服务器。

    3. onreadystatechange:存有处理服务器响应的函数,每当 readyState 改变时,onreadystatechange 函数就会被执行。

    4. readyState:存有服务器响应的状态信息。

    0: 请求未初始化(代理被创建,但尚未调用 open() 方法)

    1: 服务器连接已建立(open方法已经被调用)

    2: 请求已接收(send方法已经被调用,并且头部和状态已经可获得)

    3: 请求处理中(下载中,responseText 属性已经包含部分数据)

    4: 请求已完成,且响应已就绪(下载操作已完成)

    5. responseText:获得字符串形式的响应数据。

    6. setRequestHeader():POST传数据时,用来添加 HTTP 头,然后send(data),注意data格式;GET发送信息时直接加参数到url上就可以,比如url?a=a1&b=b1。

    PS:Fetch polyfill 的基本原理是探测是否存在window.fetch方法,如果没有则用 XHR 实现。

    原生js写法

    var Ajax={

      get: function(url, fn) {

        // XMLHttpRequest对象用于在后台与服务器交换数据 

        var xhr = new XMLHttpRequest();         

        xhr.open('GET', url, true);

        xhr.onreadystatechange = function() {

          // readyState == 4说明请求已完成

          if (xhr.readyState == 4 && xhr.status == 200 || xhr.status == 304) {

            // 从服务器获得数据

            fn.call(this, xhr.responseText); 

          }

        };

        xhr.send();

      },

      // datat应为'a=a1&b=b1'这种字符串格式,在jq里如果data为对象会自动将对象转成这种字符串格式

      post: function (url, data, fn) {

        var xhr = new XMLHttpRequest();

        xhr.open("POST", url, true);

        // 添加http头,发送信息至服务器时内容编码类型

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

        xhr.onreadystatechange = function() {

          if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 304)) {

            fn.call(this, xhr.responseText);

          }

        };

        xhr.send(data);

      }

    }

    JQuery提供的Ajax方法

    $.ajax({

        url: ,

        type: '',

        dataType: '',

        data: {

        },

        success: function(){

        },

        error: function(){

        }

    })

    jQuery ajax - ajax() 方法

    jQuery Ajax 参考手册

    实例

    通过 AJAX 加载一段文本:

    jQuery 代码:

    $(document).ready(function(){

      $("#b01").click(function(){

      htmlobj=$.ajax({url:"/jquery/test1.txt",async:false});

      $("#myDiv").html(htmlobj.responseText);

      });

    });

    HTML 代码:

    亲自试一试

    定义和用法

    ajax() 方法通过 HTTP 请求加载远程数据。

    该方法是 jQuery 底层 AJAX 实现。简单易用的高层实现见 $.get, $.post 等。$.ajax() 返回其创建的 XMLHttpRequest 对象。大多数情况下你无需直接操作该函数,除非你需要操作不常用的选项,以获得更多的灵活性。

    最简单的情况下,$.ajax() 可以不带任何参数直接使用。

    注意:所有的选项都可以通过 $.ajaxSetup() 函数来全局设置。

    语法

    jQuery.ajax([settings])

    参数 描述

    settings

    可选。用于配置 Ajax 请求的键值对集合。

    可以通过 $.ajaxSetup() 设置任何选项的默认值。

    参数

    options

    类型:Object

    可选。AJAX 请求设置。所有选项都是可选的。

    async

    类型:Boolean

    默认值: true。默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。

    注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。

    beforeSend(XHR)

    类型:Function

    发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。

    XMLHttpRequest 对象是唯一的参数。

    这是一个 Ajax 事件。如果返回 false 可以取消本次 ajax 请求。

    cache

    类型:Boolean

    默认值: true,dataType 为 script 和 jsonp 时默认为 false。设置为 false 将不缓存此页面。

    jQuery 1.2 新功能。

    complete(XHR, TS)

    类型:Function

    请求完成后回调函数 (请求成功或失败之后均调用)。

    参数: XMLHttpRequest 对象和一个描述请求类型的字符串。

    这是一个 Ajax 事件。

    contentType

    类型:String

    默认值: "application/x-www-form-urlencoded"。发送信息至服务器时内容编码类型。

    默认值适合大多数情况。如果你明确地传递了一个 content-type 给 $.ajax() 那么它必定会发送给服务器(即使没有数据要发送)。

    context

    类型:Object

    这个对象用于设置 Ajax 相关回调函数的上下文。也就是说,让回调函数内 this 指向这个对象(如果不设定这个参数,那么 this 就指向调用本次 AJAX 请求时传递的 options 参数)。比如指定一个 DOM 元素作为 context 参数,这样就设置了 success 回调函数的上下文为这个 DOM 元素。

    就像这样:

    $.ajax({ url: "test.html", context: document.body, success: function(){

            $(this).addClass("done");

          }});

    data

    类型:String

    发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。

    dataFilter

    类型:Function

    给 Ajax 返回的原始数据的进行预处理的函数。提供 data 和 type 两个参数:data 是 Ajax 返回的原始数据,type 是调用 jQuery.ajax 时提供的 dataType 参数。函数返回的值将由 jQuery 进一步处理。

    dataType

    类型:String

    预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:

    "xml": 返回 XML 文档,可用 jQuery 处理。

    "html": 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。

    "script": 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了 "cache" 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的 script标签来加载)

    "json": 返回 JSON 数据 。

    "jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。

    "text": 返回纯文本字符串

    error

    类型:Function

    默认值: 自动判断 (xml 或 html)。请求失败时调用此函数。

    有以下三个参数:XMLHttpRequest 对象、错误信息、(可选)捕获的异常对象。

    如果发生了错误,错误信息(第二个参数)除了得到 null 之外,还可能是 "timeout", "error", "notmodified" 和 "parsererror"。

    这是一个 Ajax 事件。

    global

    类型:Boolean

    是否触发全局 AJAX 事件。默认值: true。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 可用于控制不同的 Ajax 事件。

    ifModified

    类型:Boolean

    仅在服务器数据改变时获取新数据。默认值: false。使用 HTTP 包 Last-Modified 头信息判断。在 jQuery 1.4 中,它也会检查服务器指定的 'etag' 来确定数据没有被修改过。

    jsonp

    类型:String

    在一个 jsonp 请求中重写回调函数的名字。这个值用来替代在 "callback=?" 这种 GET 或 POST 请求中 URL 参数里的 "callback" 部分,比如 {jsonp:'onJsonPLoad'} 会导致将 "onJsonPLoad=?" 传给服务器。

    jsonpCallback

    类型:String

    为 jsonp 请求指定一个回调函数名。这个值将用来取代 jQuery 自动生成的随机函数名。这主要用来让 jQuery 生成度独特的函数名,这样管理请求更容易,也能方便地提供回调函数和错误处理。你也可以在想让浏览器缓存 GET 请求的时候,指定这个回调函数名。

    password

    类型:String

    用于响应 HTTP 访问认证请求的密码

    processData

    类型:Boolean

    默认值: true。默认情况下,通过data选项传递进来的数据,如果是一个对象(技术上讲只要不是字符串),都会处理转化成一个查询字符串,以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。

    scriptCharset

    类型:String

    只有当请求时 dataType 为 "jsonp" 或 "script",并且 type 是 "GET" 才会用于强制修改 charset。通常只在本地和远程的内容编码不同时使用。

    success

    类型:Function

    请求成功后的回调函数。

    参数:由服务器返回,并根据 dataType 参数进行处理后的数据;描述状态的字符串。

    这是一个 Ajax 事件。

    traditional

    类型:Boolean

    如果你想要用传统的方式来序列化数据,那么就设置为 true。请参考工具分类下面的 jQuery.param 方法。

    timeout

    类型:Number

    设置请求超时时间(毫秒)。此设置将覆盖全局设置。

    type

    类型:String

    默认值: "GET")。请求方式 ("POST" 或 "GET"), 默认为 "GET"。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。

    url

    类型:String

    默认值: 当前页地址。发送请求的地址。

    username

    类型:String

    用于响应 HTTP 访问认证请求的用户名。

    xhr

    类型:Function

    需要返回一个 XMLHttpRequest 对象。默认在 IE 下是 ActiveXObject 而其他情况下是 XMLHttpRequest 。用于重写或者提供一个增强的 XMLHttpRequest 对象。这个参数在 jQuery 1.3 以前不可用。

    回调函数

    如果要处理 $.ajax() 得到的数据,则需要使用回调函数:beforeSend、error、dataFilter、success、complete。

    beforeSend

    在发送请求之前调用,并且传入一个 XMLHttpRequest 作为参数。

    error

    在请求出错时调用。传入 XMLHttpRequest 对象,描述错误类型的字符串以及一个异常对象(如果有的话)

    dataFilter

    在请求成功之后调用。传入返回的数据以及 "dataType" 参数的值。并且必须返回新的数据(可能是处理过的)传递给 success 回调函数。

    success

    当请求之后调用。传入返回后的数据,以及包含成功代码的字符串。

    complete

    当请求完成之后调用这个函数,无论成功或失败。传入 XMLHttpRequest 对象,以及一个包含成功或错误代码的字符串。

    数据类型

    $.ajax() 函数依赖服务器提供的信息来处理返回的数据。如果服务器报告说返回的数据是 XML,那么返回的结果就可以用普通的 XML 方法或者 jQuery 的选择器来遍历。如果见得到其他类型,比如 HTML,则数据就以文本形式来对待。

    通过 dataType 选项还可以指定其他不同数据处理方式。除了单纯的 XML,还可以指定 html、json、jsonp、script 或者 text。

    其中,text 和 xml 类型返回的数据不会经过处理。数据仅仅简单的将 XMLHttpRequest 的 responseText 或 responseHTML 属性传递给 success 回调函数。

    注意:我们必须确保网页服务器报告的 MIME 类型与我们选择的 dataType 所匹配。比如说,XML的话,服务器端就必须声明 text/xml 或者 application/xml 来获得一致的结果。

    如果指定为 html 类型,任何内嵌的 JavaScript 都会在 HTML 作为一个字符串返回之前执行。类似地,指定 script 类型的话,也会先执行服务器端生成 JavaScript,然后再把脚本作为一个文本数据返回。

    如果指定为 json 类型,则会把获取到的数据作为一个 JavaScript 对象来解析,并且把构建好的对象作为结果返回。为了实现这个目的,它首先尝试使用 JSON.parse()。如果浏览器不支持,则使用一个函数来构建。

    JSON 数据是一种能很方便通过 JavaScript 解析的结构化数据。如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用 jsonp 类型。使用这种类型的话,会创建一个查询字符串参数 callback=? ,这个参数会加在请求的 URL 后面。服务器端应当在 JSON 数据前加上回调函数名,以便完成一个有效的 JSONP 请求。如果要指定回调函数的参数名来取代默认的 callback,可以通过设置 $.ajax() 的 jsonp 参数

    相关文章

      网友评论

          本文标题:ajax原理

          本文链接:https://www.haomeiwen.com/subject/cmobtctx.html