zoukankan      html  css  js  c++  java
  • $.ajax()函数

    一般在前端html和服务器交互,又要异步提交表单时,我们通常会用到$.ajax(){}函数,这是封装到ajax里的一个函数,相比于XMLHTTPRequest做页面局部刷新更方便,但最终还是使用的XMLHTTPRequest,下面记录下$.ajax()函数,以备日后回顾。

    $.ajax(){}函数格式如下:

    $.ajax({
    url: "test.aspx?r=" + Math.random(),
    type: "GET",
    data: {},
    dataType: "json",
    async: false,
    success: function (result) {
    var coin = result["coin"];
    var stage = result["stage"];

    document.write("金币:" + coin + "个,身份:" + stage);

    }
    });

    参数具体意思:

    url:请求的服务器地址,默认是当前页面,数据类型是String

    type:请求的方式,有POST和GET两种,默认是GET,数据类型是String

    data:发送到服务器的数据,数据类型是Object或者String,大括号里的对象必须为key/value格式,比如:data:{boy:"LiLei",girl:"HanMeimei",boyage:18,girlage:16}

    dataType:预期服务器返回的数据类型,数据类型是String,参数值有:

      xml:返回XML文档,可用JQuery处理。
      html:返回纯文本HTML信息;包含的script标签会在插入DOM时执行。
      script:返回纯文本JavaScript代码。不会自动缓存结果。除非设置了cache参数。注意在远程请求时(不在同一个域下),所有post请求都将转为get请求。
      json:返回JSON数据。
      jsonp:JSONP格式。使用SONP形式调用函数时,例如myurl?callback=?,JQuery将自动替换后一个“?”为正确的函数名,以执行回调函数。
      text:返回纯文本字符串。

    async:所有请求是同步还是异步,当值是true时是异步请求,为false时是同步请求。同步请求会锁住浏览器,即进入页面假死状态,用户其他操作必须等待请求完成才可以执行,请求完成以后页面假死状态解除。我们看一个例子:

    $.ajax({
      url: "test.aspx?r=" + Math.random(),
      type: "GET",
      data: {},
      dataType: "json",
      async: true,
      success: function (result) {
        function1();
        function2();
      }
    });
    function1(){alert("function1");}
    function2(){alert("function2");}

    在上例中,当ajax块发出请求后,他将停留function1(),等待server端的返回,但同时(在这个等待过程中),前台会去执行function2(),也就是说,在这个时候出现两个线程,我们这里暂且说为function1() 和function2()。当把asyn设为false时,这时ajax的请求时同步的,也就是说,这个时候ajax块发出请求后,他会等待在function1()这个地方,不会去执行function2(),直到function1()部分执行完毕。

    success:请求成功后调用的回调函数。这里必须是Function类型的参数,它有两个参数:
             (1)由服务器返回,并根据dataType参数进行处理后的数据。
             (2)描述状态的字符串。
             function(data, textStatus){
                //data可能是xmlDoc、jsonObj、html、text等等
                this;  //调用本次ajax请求时传递的options参数
             }

    常用的参数就是上面的几个,还有其它参数,如下

    timeout:请求超时时间,以毫秒为单位,数据类型是Number

    cache:是否从浏览器缓存中加载请求信息,默认为true,即从缓存中加载请求信息。

    errorFunction类型的参数,请求失败时被调用的函数。该函数有3个参数,即XMLHttpRequest对象、错误信息、捕获的错误对象(可选)。ajax事件函数如下:
           function(XMLHttpRequest, textStatus, errorThrown){
              //通常情况下textStatus和errorThrown只有其中一个包含信息
              this;   //调用本次ajax请求时传递的options参数
           }

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

    beforeSend:Function类型的参数,发送请求前可以修改XMLHttpRequest对象的函数,例如添加自定义HTTP头。在beforeSend中如果返回false可以取消本次ajax请求。XMLHttpRequest对象是惟一的参数。
                function(XMLHttpRequest){
                   this;   //调用本次ajax请求时传递的options参数
                }
    complete:Function类型的参数,请求完成后调用的回调函数(请求成功或失败时均调用)。参数:XMLHttpRequest对象和一个描述成功请求类型的字符串。
              function(XMLHttpRequest, textStatus){
                 this;    //调用本次ajax请求时传递的options参数
              }

    contentType:String类型的参数,当发送信息至服务器时,内容编码类型默认为"application/x-www-form-urlencoded"。该默认值适合大多数应用场合。

    dataFilter:Function类型的参数,给Ajax返回的原始数据进行预处理的函数。提供data和type两个参数。data是Ajax返回的原始数据,type是调用jQuery.ajax时提供的dataType参数。函数返回的值将由jQuery进一步处理。
                function(data, type){
                    //返回处理后的数据
                    return data;
                }

    dataFilter:Function类型的参数,给Ajax返回的原始数据进行预处理的函数。提供data和type两个参数。data是Ajax返回的原始数据,type是调用jQuery.ajax时提供的dataType参数。函数返回的值将由jQuery进一步处理。
                function(data, type){
                    //返回处理后的数据
                    return data;
                }

    global:Boolean类型的参数,默认为true。表示是否触发全局ajax事件。设置为false将不会触发全局ajax事件,ajaxStart或ajaxStop可用于控制各种ajax事件。

    ifModified:Boolean类型的参数,默认为false。仅在服务器数据改变时获取新数据。服务器数据改变判断的依据是Last-Modified头信息。默认值是false,即忽略头信息。

    username:String类型的参数,用于响应HTTP访问认证请求的用户名。

    password:String类型的参数,用于响应HTTP访问认证请求的密码。

    processData:Boolean类型的参数,默认为true。默认情况下,发送的数据将被转换为对象(从技术角度来讲并非字符串)以配合默认内容类型"application/x-www-form-urlencoded"。如果要发送DOM树信息或者其他不希望转换的信息,请设置为false。

    scriptCharset:String类型的参数,只有当请求时dataType为"jsonp"或者"script",并且type是GET时才会用于强制修改字符集(charset)。通常在本地和远程的内容编码不同时使用。

    跨域访问

     $.ajax({
             url:'',                      //url地址
             type:'GET',                  //jsonp 类型下只能使用GET,不能用POST,这里不写默认为GET
             dataType:'jsonp',            //指定为jsonp类型
             data:{},                     //数据参数
             jsonp:'callback',            //服务器端获取回调函数名的key;callback是默认值
             jsonpCallback:'jsonpName',   //回调函数名
             success:function(result){    //成功执行处理,对应后台返回的jsonpName(data)方法
                 
             },
             error:function(XMLHttpRequest, textStatus, errorThrown){
              //通常情况下textStatus和errorThrown只有其中一个包含信息
           } });
  • 相关阅读:
    AtCoder Regular Contest 093
    AtCoder Regular Contest 094
    G. Gangsters in Central City
    HGOI 20190711 题解
    HGOI20190710 题解
    HGOI 20190709 题解
    HGOI 20190708 题解
    HGOI20190707 题解
    HGOI20190706 题解
    HGOI 20190705 题解
  • 原文地址:https://www.cnblogs.com/huyueping/p/5132903.html
Copyright © 2011-2022 走看看