jquery中$.get(),$.post(),$.ajax(),$.getJSON()区别详解以及aja
2015-04-15 09:29
706 查看
<span style="background-color: rgb(255, 255, 255); font-family: Arial, Helvetica, sans-serif; font-size: 14px;">通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。</span>
传统的网页(不使用 AJAX)如果需要更新内容,必须重载整个网页页面。
Ajax 的核心是 JavaScript 对象 XmlHttpRequest。该对象在 Internet Explorer 5 中首次引入,它是一种支持异步请求的技术。
ajax工作远离
JQuery与Ajax关系:JQuery是javascript的一个框架 是现在比较流行的一个js框架 JQuery封装了Ajax的功能使我们用起来更加简单方便。
JQuery中$.get、$.post、$.getjson、$.ajax用法和区别
1、$.get
服务器返回数据的格式其实是字符串形势,并不是我们想要的json数据格式,在此引用只是为了对比说明。
$.get()方法使用GET方式来进行异步请求,它的语法结构为:
$.get( url [, data] [, callback] )
解释一下这个函数的各个参数:
url:string类型,ajax请求的地址。
data:可选参数,object类型,发送至服务器的key/value数据会作为QueryString附加到请求URL中。
callback:可选参数,function类型,当ajax返回成功时自动调用该函数。
例子:
<pre name="code" class="html"><pre name="code" class="html">$.get( "submit.jsp",{ id: '1', name: 'test', },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( "submit.jsp",{ id: '1', name: 'test', },function(data,state){ //这里显示从服务器返回的数据 alert(data); //这里显示返回的状态 alert(state); } "json" )
function listDistrict(){ $.post("posturl", {}, function (data) { var jsonObj = eval("(" + data + ")"); for (var i = 0; i < jsonObj.length; i++) { var $option = $("<option></option>"); var row=jsonObj[i]; for(var p in row) { $option.attr("value", row[0]); $option.text(row[p]); } $("#district").append($option); } }); }
3、$.getJSON()
$.getJSON()是专门为ajax获取json数据而设置的,并且支持跨域调用,$.ajax()这个函数功能强大,可以对ajax进行许多精确的控制,需要详细说明的请参照相关资料。
其语法的格式为:
getJSON(url,[data],[callback])
url:string类型, 发送请求地址
data :可选参数, 待发送 Key/value 参数 ,同get,post类型的data
callback :可选参数,载入成功时回调函数,同get,post类型的callback
返回的是json类型的,不需要转换。
JSON是一种理想的数据传输格式,它能够很好的融合与JavaScript或其他宿主语言,并且可以被JS直接使用。使用JSON相比传统的通过 GET、POST直接发送“裸体”数据,在结构上更为合理,也更为安全。至于jQuery的getJSON()函数,只是设置了JSON参数的 ajax()函数的一个简化版本。这个函数也是可以跨域使用的,相比get()、post()有一定优势。另外这个函数可以通过把请求url写 成"myurl?callback=X"这种格式,让程序执行回调函数X。
例子:
function listSomething(){ $.getJSON(listSomethingUrl,{id:id},function(data){ var datatable = document.getElementById("idnames"); datatable.innerHTML=""; var jsonObject = data; var tempHtml=""; for(var i=0;i<jsonObject.estimateList.length;i++){ var temp=jsonObject.estimateList[i]; tempHtml=temp.name; } datatable.innerHTML=tempHtml; }); };
4、$.ajax()
$.ajax()是jquery中通用的一个ajax封装,其语法的格式为:
$.ajax(options)
其中options是一个object类型,它指明了本次ajax调用的具体参数,这里我把最常用的几个参数附上
例子:
$.ajax({ url: 'submit.jsp', datatype: "json", type: 'post', success: function (e) { //成功后回调 alert(e); }, error: function(e){ //失败后回调 alert(e); }, beforeSend: function(){ /发送请求前调用,可以放一些"正在加载"之类额话 alert("正在加载"); } })
function changeStatus(oid,state) { if (confirm("确定修改!")) { $.ajax({ type: "post", url: updateOrderUrl, data: "&oId=" + oid + "&state=" + state, async: true, success: function(data) { if(data==-1){ alert("变更异常!"); } } }); } };
上述多次提到get、post,下一篇文章讲会对这两个请求做出详解。
相关文章推荐
- jQuery中$.get、$.post、$.getJSON、$.ajax 方法详解
- jQuery中$.get、$.post、$.getJSON、$.ajax 方法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- JQuery中$.get(),$.post(),$.ajax(),$.getJSON()的区别
- Jquery中 $.get(),$.post(),$.ajax(),$.getJSON()方法的使用与区别
- jQuery中$.get、$.post、$.getJSON、$.ajax 方法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- jquery中$.ajax $.get $.post 和$.getJSON的区别和用法
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- 深入理解JQuery中$.get()、$.post()、$.getJSON()、$.ajax()方法
- 深入理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法
- 详细解读Jquery各Ajax函数:$.get(),$.post(),$.ajax(),$.getJSON()
- 详细解读Jquery各Ajax函数:$.get(),$.post(),$.ajax(),$.getJSON()
- 如何解决Ajax访问不断变化的session的值不一致以及HTTP协议中的GET、POST的区别
- JQuery加载外部文件的方式get、post、ajax、load的区别及异步加载的实现
- jQuery 之 $.get、$.post、$.getJSON、$.ajax
- jQuery中各Ajax函数:$.get(),$.post(),$.ajax(),$.getJSON()
- Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结