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

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

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" ----返回对象)
.error(function() {layer.msg("操作失败!请稍后重试!",{icon: 5,time:2000});}); ----异常回调函数

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。

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("正在加载");
}
})

$.ajax({
type : 'POST',

contentType : 'application/json', ----不使用contentType: “application/json”则data可以是对象
----使用contentType: “application/json”则data只能是json字符串

url : "${pageContext.request.contextPath}/person/login",

processData : false, ----用于对data参数进行序列化处理,调用返回值:StringjQuery.param把{ width:1680, height:1050 }
----参数对象序列化为width=1680&height=1050这样的字符串。
dataType : 'json',

data : {xxx:'date'},

async: false, -----false:同步请求,true:异步请求

success : function(data) {
alert("id: " + data.id + "\nname: " + data.name + "\nstatus: "
+ data.status);
},
error : function() {
alert('出错了!');
}
});


以上就是jquery实现ajax调用的几种方法,ajax调用还是挺复杂的,希望本文能对大家有所帮助,如有什么疑问,也可以联系我,大家共同进步。


更多相关文章

  1. $ .post请求中的回调函数
  2. 利用jQuery的$.event.fix函数统一浏览器event事件处理
  3. 仅当鼠标停留在元素上时,jQuery才会激活鼠标悬停函数
  4. jQuery循环没有每个和回调函数
  5. Jquery Validate 相关参数及常用的自定义验证规则
  6. JavaScript函数中的Ruby代码
  7. jQuery.parseJSON()函数详解
  8. 从内部获取函数名称
  9. Jquery 1.9, JS -函数在Chrome中没有定义

随机推荐

  1. Android: ADB网络调试
  2. Android 4G驱动移植流程
  3. android studio 错误总结
  4. Android SQLiteOpenHelper
  5. Android Custom Views and XML attribute
  6. Android获取/清除应用数据
  7. Android SDK R14 发布
  8. 如何提高android代码质量
  9. android中的颜色值
  10. 在android中玩转wcf