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

    当我们用javascript写ajax程序写得很“开心”的时候,突然有人告诉你有一种东西叫jquery,它会告诉你不直接和HttpRequest是多么的快乐,同时你再也不需要再烦恼纠结的ajax乱码问题,更幸福的是你的js代码将大大地简化,看完本文,你会发现,ajax,简单的来讲就是一句话的事情。

    本文重点是来讲讲jQuery中调用ajax的4种方法:$.get、$.post、$getJSON、$ajax。如果读者没有javascript和jquery的知识,或者没有ajax的概念,那么请先去问问google老大,再来读本文。

    1、$.get

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

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

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

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

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

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

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

     

    $.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()的实例供大家参考:

     

    $.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调用的具体参数,这里我把最常用的几个参数附上

     

    $.ajax({

            url: 'submit.aspx',

            datatype: "json",

            type: 'post',

            success: function (e) {

            //成功后回调

                alert(e);

             },

            error: function(e){

        //失败后回调

                alert(e);

            },

            beforeSend: function(){

     //发送请求前调用,可以放一些"正在加载"之类额话

                alert("正在加载");        

    }})

    好了,以上就是jquery实现ajax调用的几种方法,希望对大家有所帮助。

     

    原文链接:http://www.tzwhx.com/NewShow/newBodyShow/jquery%E5%9F%BA%E7%A1%80_23339.html

    时不我待,不负韶华!立刻行动!不吃学习的苦就会吃生活的苦!
  • 相关阅读:
    java中this关键字
    java继承
    java super关键字
    java String类型存储详解
    java四种访问权限修饰符
    C/C++语言void及void指针深层探索【转】
    Linux Epoll介绍和程序实例【转】http://blog.csdn.net/sparkliang/article/details/4770655
    服务器与wp7的socket通信【转】 http://www.cnblogs.com/linzheng/archive/2011/06/21/2086456.html
    android关于socket编程,以聊天为例【转】http://hi.baidu.com/yaoyuanhuajx/item/9b93d7565f315ba9acc857d7
    Tesseract 3 语言数据的训练方法【转】http://blog.csdn.net/dragoo1/article/details/8439373
  • 原文地址:https://www.cnblogs.com/zrp2013/p/3153962.html
Copyright © 2011-2022 走看看