zoukankan      html  css  js  c++  java
  • jQuery中$.get、$.post、$.getJSON和$.ajax的用法

    以下是本人原创,如若转载和使用请注明转载地址。本博客信息切勿用于商业,可以个人使用,若喜欢我的博客,请关注我,谢谢!博客地址

    一、jQuery中调用ajax的4种方法:$.get、$.post、$getJSON、$ajax

    1、$.get

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

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

    解释一下这个函数的各个参数:

    url:string类型,ajax请求的地址。

    data:可选参数,object类型,发送至服务器的key/value数据会作为QueryString附加到请求URL中。

    callback:可选参数,function类型,当ajax返回成功时自动调用该函数。

    最后写一个$.get()的实例供大家参考:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    $.get(    "submit.aspx",
     
             {        id:     '123',        name:   '青藤园',    },
     
             function(data,state){       
     
             //这里显示从服务器返回的数据       
     
            alert(data);      
     
             //这里显示返回的状态    
     
            alert(state);    })

    2、$.post()

    $.post()方法使用POST方式来进行异步请求,它的语法结构为:

    $.post(url,[data],[callback],[type])

    这个方法和$.get()用法差不多,唯独多了一个type参数,那么这里就只介绍type参数吧,其他的参考上面$.get()的。

    type:type为请求的数据类型,可以是html,xml,json等类型,如果我们设置这个参数为:json,那么返回的格式则是json格式的,如果没有设置,就和$.get()返回的格式一样,都是字符串的。

    最后写一个$.post()的实例供大家参考:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $.post(    "submit.aspx",
            {        id:     '123',        name:   '青藤园',    },
            function(data,state){       
            //这里显示从服务器返回的数据       
     
                  alert(data);      
     
            //这里显示返回的状态     
     
                  alert(state);  
     
             },   
     
            "json");

     3、$.getJSON()

    $.getJSON()是专门为ajax获取json数据而设置的,并且支持跨域调用,其语法的格式为:

    getJSON(url,[data],[callback])

    url:string类型, 发送请求地址
    data :可选参数, 待发送 Key/value 参数 ,同get,post类型的data
    callback :可选参数,载入成功时回调函数,同get,post类型的callback

    JSON是一种理想的数据传输格式,它能够很好的融合与JavaScript或其他宿主语言,并且可以被JS直接使用。使用JSON相比传统的通过 GET、POST直接发送“裸体”数据,在结构上更为合理,也更为安全。至于jQuery的getJSON()函数,只是设置了JSON参数的 ajax()函数的一个简化版本。这个函数也是可以跨域使用的,相比get()、post()有一定优势。另外这个函数可以通过把请求url写 成"myurl?callback=X"这种格式,让程序执行回调函数X。

    提示:数据最终还是通过url后面通过get方式发送数据出去的,这就决定了,发送的data数据量不能太多,否则造成url太长接收失败(getJSON方式是不可能有post方式递交的)。

    4、$.ajax()

    $.ajax()是jquery中通用的一个ajax封装,其语法的格式为:

    $.ajax(options)

    其中options是一个object类型,它指明了本次ajax调用的具体参数,这里我把最常用的几个参数附上

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    $.ajax({
     
            url: 'submit.aspx',
     
            datatype: "json",
     
            type: 'post',
     
            success: function (e) {
     
            //成功后回调
     
                alert(e);
     
             },
     
            error: function(e){
     
        //失败后回调
     
                alert(e);
     
            },
     
            beforeSend: function(){
     
     //发送请求前调用,可以放一些"正在加载"之类额话
     
                alert("正在加载");       
     
    }})

    二、这里重点讲解$.getJSON的用法

    服务器脚本,返回JSON数据:

    $.getJSON.php
    1
    2
    3
    $arr=array("name"=>"zhangsan", "age"=>20);
    $jarr=json_encode($arr);
    echo $jarr;

    注意两点:
    第一:在返回客户端之前,先用PHP函数json_encode将要返回的数据进行编码。
    第二:返回到客户端用的是echo,而不是return。
     

    下面是核心的客户端代码:

    ​$.getJSON.html

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <script language="javascript" type="text/javascript" src="./js/jquery.js"></script>
    <script language="javascript" type="text/javascript">
    function getjs()
    {
      $.getJSON("$.getJSON.php", {}, function(response){
                     alert(response.age);
      });
    }
      
    <input type="button" name="btn" id="btn" value="test" onClick="javascript:getjs();"/>

    注意一点:
    由于在PHP中是用JSON编码返回值,所以此处必须用getJSON去调用PHP文件,从而获取数据。同时可以注意到,经由getJSON得到的数据已经变成了一个对象数组,可以用response.name,response.age很直观的获取返回值。


    感谢您支持我的博客,我的动力是您的支持和关注!如若转载和使用请注明转载地址,并且请尊重劳动成果,谢谢!





  • 相关阅读:
    Hive2.0函数大全(中文版)
    Centos7 安装并配置redis
    Java内部类
    beeline: 新版连接Hive server的工具
    jsoup的Document类
    Jsoup类
    jsoup的Node类
    jsoup的Element类
    Java中的多线程
    Java中的文件IO流
  • 原文地址:https://www.cnblogs.com/wang3680/p/f1d3f971d4c997ed4f2760b3865e7395.html
Copyright © 2011-2022 走看看