zoukankan      html  css  js  c++  java
  • jQuery中的Ajax

    一、Ajax介绍

      1.什么是Ajax

       异步的JavascriptXML技术(可简单理解为 无刷新的数据更新)

      2.Ajax原理:

        -->运用XHTML+CSS表达信息

      -->运用JS操作DOM运行动态效果

       -->运用XMLXSLT进行数据交换及操作

       --》运用XMLHttpRequestAgent与网页服务器进行异步数据交换

       --》运用JS实现

      3.Ajax优点:

        (1)不需要任何浏览器插件,在任何支持JavaScript的浏览器上运行

        (2)优秀的用户体验(在不更新整个页面的前提下维护数据)

        (3)提高了Web性能(通过XMLHttpRequest对象向服务器端提交希望提交的数据)

        (4)减轻服务器和带宽的负担;把传统方式下的一些服务器负担的工作转移到了客户端

      4.Ajax缺点:

        (1).可能破坏浏览器后退按钮的正常行为

        (2)对搜索引擎的支持不足

        (3)开发和调试工具的缺乏

        (4)手持设备支持性差

      补充:

        (1)W3C标准(站点标准):

      网页主要有三部分组成:结构、表现和行为。

      对应的标准也分三方面:结构化标准语言(XHTMLXML)、表现标准语言(CSS)、行为标准主要包括对象模型(如W3C DOMECMAScript)。

      异步请求:局部请求,局部刷新;将请求给后台处理,但程序不等待处理结果而继续运行, 程序不等待响应,在运行时也能接收响应。

      5.XMLHttpRequest对象

     Ajax的核心是XMLHttpRequest对象,它是Ajax实现的关键。Ajax利用它来发送异步请求、接收响应及执行回调。

     XMLHttpRequest对象的属性:

        (1)Readystate

       HTTP请求状态,当一个XMLHttpRequest初次建立时,这个属性的值从0开始,直到接收到完整的HTTP响应,这个值增加到4

                   状态、名称和含义

    状态

    名称

    描述

    0

    Uninitialized

    初始化状态。XMLHttpRequest对象已创建或已被abort()方法重置

    1

    Open

    Open()方法已调用,但send()方法为调用。请求还没有被发送

    2

    Send

    Send()方法已调用,HTTP请求已发送到Web服务器。未接收到响应

    3

    Receiving

    所有响应头都已就收到。响应体开始接收但未完成

    4

    Loaded

    HTTP响应已完全接收

      ReadyState的值不会递减,除非当一个请求在处理过程中时调用了abort()open()方法。

        (2)responseText

      从服务器接收到的响应体(不包括头部),如果还没有接收到数据,就是空字符串。

      当readyState小于3,这个属性就是一个空字符串;等于3,这个属性返回目前已经接收的响应部分;等于4,这个属性保存了完整的响应体。

        (3)responseXML

      对请求的响应,解析为XML并作为Document对象返回。

        (4)Status

      由服务器返回的HTTP状态码,如200表示成功;404表示“Not Found”错误。当readystate小于3时读取这个属性会导致一个异常。

        (5)statusText

      此属性用名称而不是数字指定了请求的HTTP状态码。200---OK”,404---Not Found”。

      XMLHttpRequest对象的方法:

        (1)abort()

      取消当前响应,关闭连接并结束任何未完成的网络活动。Abort()方法把XMLHttpRequest对象的readyState属性重置为0的状态且取消所有未决的网络活动。如:请求用了太长时间,  且响应不在必要的时候,可调用此方法。

        (2)getAllResponseHeaders()

      把HTTP响应头部作为未解析的字符串返回。如果readyState小于3,这个方法返回null。否则(作为单个字符串)返回服务器发送的所有HTTP响应的头部。

        (3)getResponseHeader()

      返回指定的HTTP响应头部的值 

        (4)open()

      Open(method,url,async,username,password)

      初始化HTTP请求参数;行为:保存供send()方法使用的请求参数,及重置XMLHttpRequest对象以复用。

        (5)send()

      Send(body)

      发送HTTP请求,使用传递给open()方法的参数,及传递给该方法的可选请求体。

        (6)setRequestHeader()

      SetRequestHeader(name,value)

      Name:要设置的头部名称。这个参数不应该包括空白、冒号或换行。

      Value:头部的值。这个参数不应该包括换行。

      向一个打开但未发送的请求设置或添加一个HTTP请求

      XMLHttpRequest对象的事件句柄:

        (1)Onreadystatechange

      ReadyState属性改变的时候调用的事件句柄函数。当readyState3时,它可能被调用多次。

      6.JavaScript Ajax示例

        1)先声明一个异步请求对象

      //声明一个空对象用来装入XMLHttpRequest

      Var xmlHttpRequest=null;

        2) 给对象赋值,要考虑浏览器的兼容性

      //IE5IE6是以ActiveXObject的方式引入XMLHttpRequest

      If(window.ActiveXObject)

      {

      xmlHttpReq=new ActiveXObject(“Microsoft.XMLHTTP”);

      //IE5 IE6以外的浏览器XMLHttpRequestwindow的子对象

      }else if(window.XMLHttpRequest)

      {

      //实例化一个XMLHttpRequest

      xmlHttpReq=new XMLHttpRequest();

      }

        3)调用open()方法,指定异步请求的url

      //如果对象实例化成功

      If(xmlHttpReq!=null)

      {

      //调用open()方法并采用异步方式

      xmlHttpReq.open(“GET”,”FirstHandler.ashx”,true);

      调用send()方法,向服务器发送异步请求

      xmlHttpReq.send(null);

      xmlHttpReq.onreadystatechange=doResult;//设置回调函数

      }

      //回调函数

      //一旦readystate值改变,将会调用这个函数,readystate=4表示完成响应

      function doResult(){

      if(xmlHttpReq.readyState==4)

      {

      If(xmlHttpReq.status==200)

      {

      //xmlHttpReq.responseText的值赋给IDresText的元素

      document.getElementById(“resText”).innerHTML=xmlHttpReq.responseText;

      }

      }

      }

     

    二、jQuery中的Ajax

       jQueryAjax操作进行了封装,在jQuery$.ajax()方法属于最底层的方法,第2层是load()$.get(),3层是$.getScript()$.getJSON()方法。

      1.load()方法

      通常用来载入远程HTML代码并将加载的HTML代码插入DOM中。语法如下:

      load(url[data][callback]);

      参数说明:

        url:表示请求的HTML页面的url

       data(可选);发送到服务器端的Key/value数据(一般是json格式),为object类型

       callback(可选):请求完成(无论成功或失败)时的回调函数

        1)load()加载指定的HTML文件,代码如下:

      $(function()
    
      {
    
        $("#btnload").click(function(){ //id为btnload按钮的点击事件
    
        $("#divComment").load("Comment.html");   //id为divComment的DIV的load事件
      })
      });
    <body>
      

    <div id="comment" >

    
    

            <ul>

    
    

                <li>留言:<a href="#">李四</a></li>

    
    

                <div>你好!</div>

    
    

                <li>留言:<a href="#">王五</a></li>

    
    

                <div>你在哪儿呢?</div>

    
    

                <li>留言:<a href="#">李四</a></li>

    
    

                <div class="selLoad">哈哈,不错,很精彩</div>

    
    

            </ul>

    
    

        </div>


    </body>

        2)load()还可以筛选载入文档的HTML文档,用法是:load(url selector):

      

    $(function()
    
              {
    
                  $("#btnLoad").click(function()
    
                  {
    
                     $("#divComment").load("Comment.html .selLad")
    
                  });
    
              })

     

     

        3)传递方式

      Load()方法的传递方式根据参数data来自动指定

      无参数传递,get方式

      $(“#divComment”).load(“Comment.aspx”,function(){});

      有参数传递,post方式

      $(“#divComment”).load(“Comment.html”,{name:”Golsing”,age:”30”},function(){});

        4) 回调参数.

      

    $("#divComment").load("Comment.html",function(responseText,textStatus,XMLHttpRequest)
    
                {
    
                    alter($(this).html());//this指的是当前的DOM对象
    
                    alter(responseText);  //请求返回的内容
    
                    alter(textStatus);  //请求状态:success,error
    
                    alter(XMLHttpRequest); //XMLHttpRequest对象
    
                });

     

      2.jQuery.get()方法和jQuery.post()方法

      $.get()$.post()方法是jquery中的全局函数.

          (1).jquery.get()方法

      $.get()方法使用get方式来进行异步请求,语法结构:

      $.get(url,[data],[callback],[type]);

      url:待载入页面的url地址

      data: (可选)待发送Key/value参数

      callback : (可选)载入成功时回调函数

      type: (可选)返回内容格式,xml,html,script,json,default.

        (2)jQuery.post()方法

      $.post()方法通过远程HTTP POST 请求爱如信息,语法结构同$.get();

     

      补充:GET提交方式和POST提交方式的区别:

      get请求会将参数跟在URL后进行传递,post请求则是作为HTTP消息的实体内容发送给服务器

      get方式对传输的数据有大小限制(通常不大于2KB),post传递方式在理论上不受先制

      get方式请求的数据会被浏览器缓存,如帐号.密码等.不安全性.post方式相对来说安全性要高.

      在ASP.NET,get方式传递的数据用request.QueryString获取,postRequest.Form获取,两种传递方式也都可以用Request.Params来获取

     

      3.jQuery.getScript()方法

      通过HTTP Get请求载入并执行一个JavaScript文件

        $.getScript(url,callback)

      -->待载入js文件地址

        $.getScript(“test.js”,function({}));

      4.jQuery.getJSON()方法

        $.getJSON()方法用于加载JSON文件,使用方法和getScript()方法相同.

     

      三 jQuery.ajax()方法

        $.ajax()常用参数:

    参数名称

    参数类型

    参数说明

    url

    String

    发送请求的地址

    Type

    String 

    请求方式(get post),默认为“get;putdelete也可使用仅部分浏览器支持

    Timeout

    Number

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

    Data

    Object,string

    发送到服务器的数据,将自动转换为请求字符串格式

    DataType

    string

    预期服务器返回的数据类型,如果是json就会转换成一个JavaScript对象

    beforeSend(XHR)

    function

    发送请求前可修改XMLHttpRequest对象的函数,是一个Ajax事件

    Success

    Function

    请求成功后的回调函数

    Error

    Function

    请求失败时调用

    Complete

    Function

    请求完成后回调函数,参数:XMLHttpRequest对象和一个描述成功请求类型的字符串

    Async

    boolean

    默认设置下,所有请求均为异步请求,如要设为同步,将选项设为flase

    cache

    boolean

    默认:true,dataTypescriptjson时默认为flase,设置为flase将不缓存页面

      dataType类型:

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

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

        script:返回纯文本JavaScript代码。不会自动缓存结果。除非设置了“cache”参数。

      注意:

      在远程请求时(不在同一个域下),所有post请求都将转为get请求。(因为将使用DOMscript标签来加载)

      --》“json”返回json数据。

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

      --》“text:返回纯文本字符串

       

    $.ajax({
    
                    url:"test.html",
    
                    cache:false,
    
                    success:function(html){
    
                        $("#result").append(html);
    
                    }
    
                });

      2.序列化元素

        当我们用Ajax提交少量的数据时,可以将字段的值逐个添加到data参数中。

       

    $("#btnSubmit").click(function()
    
                {
    
                    $.get("MessageHandler.ashx",
    
                            {
    
                                //json格式传递的参数,服务器端用QueryString获取
    
                                username:$("#txtUserName").val(),
    
                                contact:$("#txtContact").val(),
    
                                message:$("#txtMessage").val()
    
                            },
    
                            //回调函数,data成功后服务器端返回的数据,格式是xml,json,html等
    
                            function(data,textStatus)
    
                            {
    
                                $("#divContact").append(data);//把返回的数据追加到div中
    
                                //textStatus参数(可省)为请求状态:success,error,notmodified,timeout等四种状态
    
                                alter(textStatus);
    
                            }
    
                    )
    
                });

        (1).serialize()方法

      当要提交大量数据时,为了简便操作可使用serialize()方法

      

      $("#btnSubmit").click(function()
    
               {
    
                   $.get("MessageHandler.ashx",
    
                   //json格式传递的参数,服务器用QueryString获取
    
                        $("#form1").serialize(),
    
                     //回调函数,data成功后服务端返回数据,格式是xml,json,html等
    
                        function(data,textStatus)
    
                        {
    
                            $("#divContent").append(data);
    
                            alter(textStatus);
    
                        }
    
                   )
    
               });

        (2).serialieArray()方法

      将DOM元素序列化后,返回JSON对象格式的数据

        (3).$.param()方法

      Serialize()方法的核心,用来对一个数组或对象按照key/value进行序列化

     

       jQuery中的全局事件

                            Ajax全局事件中的方法

    方法名称

    方法说明

    ajaxSend(callback)

    AJAX请求发送前执行的函数

    ajaxError(callback)

    AJAX请求发生错误时执行的函数

    ajaxSuccess(callback)

    AJAX请求成功时执行的函数

    ajaxComplete(callback)

    AJAX请求完成时执行的函数

  • 相关阅读:
    安装node配置环境变量,解决某组件(如cordova,webpack等)“不是内部命令”问题
    用js控制css属性
    用javascript动态改变网页文字大小
    在无代码文件的aspx文件中添加类、函数和字段的方法
    HBase-0.98.3 如何调整RPC连接的数量
    double类型相等判断 [转]
    Virtual Memory Usage from Java under Linux [转]
    手工释放SWAP空间的方法[转]
    maven配置 指定jdk版本
    maven配置: 生成war的同时生成jar, 并在其他artifact配置依赖于这个jar
  • 原文地址:https://www.cnblogs.com/chef5-3/p/3484710.html
Copyright © 2011-2022 走看看