以下是本人原创,如若转载和使用请注明转载地址。本博客信息切勿用于商业,可以个人使用,若喜欢我的博客,请关注我,谢谢!博客地址
一、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数据:
1
2
3
|
$arr = array ( "name" => "zhangsan" , "age" =>20);
$jarr =json_encode( $arr );
echo $jarr ;
|
下面是核心的客户端代码:
$.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();" />
|