jQuery中Ajax的get、post等方法详解
load()方法通常用来从Web服务器上获取静态的数据文件,然而这并不能体现ajax的全部价值。
在项目中,如果需要传递一些参数给服务器中的页面,那么可以使用$.get()或者$.post()方法(或者是$.ajax()方法)
$.get()方法使用GET方式来进行异步请求。结构为:$.get(url[,data][,callback][,type])
$.get()方法参数解释如下:
$.post()方法。
$.post()和$.get()方法的结构和使用方式相同,不过它们之间仍然有以下区别:
GET请求会将参数跟在URL后进行传递,而POST请求则是作为HTTP消息的实体内容发送给Web服务器。
GET方式对传输的数据有大小限制(通常不大于2KB),而使用POST方式传递的数据量要比GET方式大得多(理论上不受限制)
GET方式请求的数据会被浏览器缓存起来,因此其他人就可以从浏览器的历史记录中读取到这些数据,例如账号和密码等。在某种情况下,GET方式会带来严重的安全性问题,而POST方式相对来说可以避免这些问题
GET方式和POST方式传递的数据在服务器端的获取也不相同。
$.getScript():jQuery提供了此方法来直接加载js文件,与加载一个HTML片段一样简单方便,并且不需要对JavaScript文件进行处理,JavaScript文件会自动执行。
jQuery代码如下:
$(function(){ $("#send").click(function(){ $.getScript("test.js"); }); })
与其他ajax方法一样,$.getScript()方法也有回调函数,它会在JavaScript文件载入成功后运行。
例如:想载入jQuery官方颜色动画插件(jquery.color.js),成功后给元素绑定颜色变化动画:
<!DOCTYPEhtml> <html> <headlang="en"> <metacharset="UTF-8"> <scripttype="text/javascript"src="../../js/jquery-2.1.3.js"></script> <style> *{margin:0;padding:0;} body{font-size:12px;} .comment{margin-top:10px;padding:10px;border:1pxsolid#ccc;background:#DDD;} .commenth6{font-weight:700;font-size:14px;} .para{margin-top:5px;text-indent:2em;background:#DDD;} .block{width:80px;height:80px;background:#DDD;} </style> <title></title> </head> <body> <buttonid="go">运行</button> <divclass="block"></div> </body> <scripttype="text/javascript"> $(function(){ $.getScript("jquery.color.js",function(){ $("#go").click(function(){ $(".block").animate({backgroundColor:'pink'},1000) .animate({backgroundColor:'blue'},1000); }); }) }) </script> </html>
$.getJson():该方法用于加载JSON文件,用法与$.getScript()相同。
<!DOCTYPEhtml> <html> <headlang="en"> <metacharset="UTF-8"> <scriptsrc="../../js/jquery-2.1.3.js"></script> <style> *{margin:0;padding:0;} body{font-size:12px;} .comment{margin-top:10px;padding:10px;border:1pxsolid#ccc;background:#DDD;} .commenth6{font-weight:700;font-size:14px;} .para{margin-top:5px;text-indent:2em;background:#DDD;} </style> <title></title> </head> <body> <br/> <p> <inputtype="button"id="send"value="加载"/> </p> <div class="comment">已有评论:</div> <divid="resText"> </div> </body> <scripttype="text/javascript"> $(function(){ $('#send').click(function(){ $.getJSON('test.json',function(data){ $('#resText').empty(); varhtml=''; $.each(data ,function(commentIndex,comment){ html+='<divclass="comment"><h6>'+comment['username']+':</h6><pclass="para">'+comment['content']+'</p></div>'; }) $('#resText').html(html); }) }) }) </script> </html>
test.json文件为:
[ { "username":"张三", "content":"沙发." }, { "username":"李四", "content":"板凳." }, { "username":"王五", "content":"地板." } ]
使用JSONP形式的回调函数来加载其他网站的JSON数据。例如:
<!DOCTYPEhtml> <html> <headlang="en"> <metacharset="UTF-8"> <scriptsrc="../../js/jquery-2.1.3.js"></script> <style> *{margin:0;padding:0;} body{font-size:12px;} .para{ width:100px; height:100px; margin:5px; border:0; } </style> <title></title> </head> <body> <p> <inputtype="button"id="send"value="加载"/> </p> <divid="resText"> </div> </body> <scripttype="text/javascript"> $(function(){ $('#send').click(function(){ $.getJSON("https://api.flickr.com/services/feeds/photos_public.gne?tags=car&tagmode=any&format=json&jsoncallback=?", function(data){ $.each(data.items,function(i,item){ $("<imgclass='para'/>").attr("src",item.media.m).appendTo("#resText"); if(i==3){ returnfalse; } }); } ); }) }) /** * JSONP(JSONwithPadding)是一个非官方的协议,它允许在服务器端集成Scripttags返回至客户端,通过JavaScriptCallback的形式实现跨域访问 * 上述的url地址并不能请求到数据,仅用作说明。 **/ </script> </html>
注意:
jQuery将自动把URL里的回调函数,例如"url?callback=?"中的后一个”?“替换为正确的函数名,以执行回调函数。
JSONP(JSONwithPadding)是一个非官方的协议,它允许在服务器端集成Scripttags返回至客户端,通过JavaScriptCallback的形式实现跨域访问。由于JSON只是一种含有简单括号结构的纯文本,因此许多通道都可以交换JSON消息。而由于同源策略的限制,开发人员不能在于外部服务器进行通信的时候使用XMLHttpRequest。而JSONP是一种可以绕过同源策略的方法,即通过使用JSON和<script>标记相结合的方法,从服务器端直接返回可执行的JavaScript函数调用或者JavaScript对象。目前JSONP已经成为各大公司的Web应用程序跨域首选。
$.ajax()方法时jQuery最底层的ajax实现。它的结构为:
$.ajax(options).该方法只有一个参数,但在这个对象里包含了$.ajax()方法所需要的请求设置以及回调函数等信息,参数以key/value的形式存在,所有参数都是可选的,
常用参数列表为: