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

$.get("submit.php",{id:'123',name:'小王',},function(data,state){            

 //这里显示从服务器返回的数据            

  alert(data);          

//这里显示返回的状态                

 if(state == 'ok'){      

           alert("返回数据成功");      

        }else{      

            alert("返回数据失败");      

        }      

});      

2、$.post()      

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

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

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

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

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

$.post("submit.php",{id:'123',name:'小明',},      

        function(data,state){              

  //这里显示从服务器返回的数据             

        alert(data);      

   //这里显示返回的状态          

   if(state == 'ok'){      

            alert("返回数据成功");      

        }else{      

           alert("返回数据失败");      

 },"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("回调函数成功了");      

         },      

        error: function(e){      

  //失败后回调      

            alert("服务器请求失败");      

        },      

        beforeSend: function(){      

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

            alert("正在加载");           

}})   

posted @ 2017-09-06 10:31  晨莳c  阅读(835)  评论(0编辑  收藏  举报