jQuery Ajax使用心得詳細(xì)整理及注意事項(xiàng)
IE7及以下請(qǐng)求方式用GET的話,URL的限制是個(gè)很容易忽視的問(wèn)題(最大2083個(gè)字符)。所以如果URL有可能過(guò)長(zhǎng)的話,一定要用POST。
--------------------------------------------------------------------------------
終止Ajax請(qǐng)求
終止請(qǐng)求需要調(diào)用XMLHttpRequest對(duì)象的abort()方法
而在jQuery中的$.get,$.post、$.ajax、$.getJSON、$.getScript...的返回值都是XMLHttpRequest對(duì)象.
調(diào)用abort()后,ajax請(qǐng)求立即停止,但仍然會(huì)執(zhí)行success的回調(diào)函數(shù)
所以在success的回調(diào)函數(shù)中需要先判斷 ajaxGet 或 data是否存在,存在才執(zhí)行回調(diào)函數(shù)
var ajaxGet = $.get(someURL,someData,function(data){
if(!data)return true;
//TODO
});
ajaxGet.abort();
說(shuō)到跨域資源共享(CORS Cross-Origin Resoure Sharing),現(xiàn)在正變的越來(lái)越重要。各種地圖API,微博API等等,網(wǎng)站開發(fā)人員不必自己去放衛(wèi)星,只要根據(jù)別人開放的接口,就能獲取到這些數(shù)據(jù)。
這得益于跨源策略。
JSONP就是跨源策略的一種方案?;驹砭褪抢脼g覽器允許跨域獲取script資源(包括圖片)的特點(diǎn),在服務(wù)器端生成script Tag,并傳回客戶端。
要注意的是,服務(wù)器端返回的不是JSON格式的字符串,而是callbackName+"("+JSON_string+")"也就是JSONP。
這就相當(dāng)于服務(wù)器把一段JS代碼(被賦值的函數(shù))返回瀏覽器,然后立即執(zhí)行。
所以,在瀏覽器端發(fā)送的URL中(以GET的形式),需要把回調(diào)函數(shù)名傳入。
客戶端:
function deal(data){
//TODO
}
var s= document.createElement("script")
//不必一定叫callback,但是一定要跟服務(wù)器端的Request.QueryString匹配
s.src = "http://172.20.2.60:8088/newwebsite/MyHandler.ashx?callback=func";
document.body.appendChild(s)
服務(wù)器端(.Net)
<%@ WebHandler Language="C#" Class="Test" %>
using System;
using System.Web;
public class Test : IHttpHandler {
public void ProcessRequest (HttpContext context) {
context.Response.Charset = "utf-8";
context.Response.ContentType = "text/javascript";
string callback = context.Request.QueryString["callback"];//回調(diào)函數(shù)名
string json = "{'name':'Ray','msg':'hello world!'}";//JSON格式的字符串
string result = string.Format("{0}({1})", callback, json);
context.Response.Write(result);
context.Response.Flush();
context.Response.End();
}
public bool IsReusable {
get {
return false;
}
}
}
用jQuery的話,URL中就不用加回調(diào)函數(shù)名了,因?yàn)閖Query已經(jīng)為你代勞了,而這個(gè)回調(diào)函數(shù)就是success。
$.ajax({
url: "http://172.20.2.60:8088/newwebsite/MyHandler.ashx"
, dataType: "jsonp"
, success: function(data) {
//TODO
}
});
不管怎么說(shuō)你都是從別人的地盤倒騰數(shù)據(jù),而且內(nèi)容還是腳本!也就是說(shuō)如果人家是個(gè)壞人,給你點(diǎn)惡意代碼,那就不好辦了。
當(dāng)然這個(gè)問(wèn)題一般也不會(huì)發(fā)生。畢竟咱想請(qǐng)求數(shù)據(jù)的地方都是咱熟悉的要么就是官方的(什么谷歌地圖API,新浪微博API這些顯然不會(huì)給你坑)。
另一個(gè)問(wèn)題就鬧心了。瀏覽器端對(duì)JSONP的請(qǐng)求是否失敗是無(wú)法直接知曉的。就算用jQuery,error也不起作用。就算出錯(cuò)了try,catch也捕捉不到。
所以暫時(shí)知道的只有一種不完美方法,就是設(shè)定一個(gè)時(shí)限,如果超過(guò)時(shí)限還沒(méi)有數(shù)據(jù)返回,那么就判定error。說(shuō)不完美是因?yàn)?,各家的網(wǎng)速是不同的,所以...你懂得。
--------------------------------------------------------------------------------
jQuery中contentType相關(guān)
jQuery官網(wǎng)原文
contentType
Default: 'application/x-www-form-urlencoded; charset=UTF-8'
When sending data to the server, use this content type.
Default is "application/x-www-form-urlencoded; charset=UTF-8", which is fine for most cases.
If you explicitly pass in a content-type to $.ajax(),
then it'll always be sent to the server (even if no data is sent).
If no charset is specified, data will be transmitted to the server using the server's default charset;
you must decode this appropriately on the server side.
通過(guò)這段文字我們就可以知道在jQuery ajax中 contentType默認(rèn)是'application/x-www-form-urlencoded; charset=UTF-8' 當(dāng)然這是最新版jQuery的。相對(duì)于以前版本是有些許變化的。
如果想將一個(gè)對(duì)象序列化后傳向后臺(tái),可以將contentType設(shè)置為'application/json'
相關(guān)文章
js與jQuery實(shí)現(xiàn)的兼容多瀏覽器Ajax請(qǐng)求實(shí)例
這篇文章主要介紹了js與jQuery實(shí)現(xiàn)的兼容多瀏覽器Ajax請(qǐng)求,以實(shí)例形式分別講述了采用純js與jQuery實(shí)現(xiàn)的兼容多瀏覽器Ajax請(qǐng)求的方法,并對(duì)Ajax中出現(xiàn)的亂碼問(wèn)題進(jìn)行了一定的分析,需要的朋友可以參考下2014-11-11Ajax讀取txt并對(duì)txt內(nèi)容進(jìn)行分頁(yè)顯示功能
這篇文章給大家介紹了Ajax讀取txt并對(duì)txt內(nèi)容進(jìn)行分頁(yè)顯示功能,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-11-11Django框架利用ajax實(shí)現(xiàn)批量導(dǎo)入數(shù)據(jù)功能
這篇文章主要介紹了Django框架利用ajax實(shí)現(xiàn)批量導(dǎo)入數(shù)據(jù)功能的相關(guān)資料,需要的朋友可以參考下2016-03-03javascript Ajax獲取遠(yuǎn)程url的返回判斷
將以下文本放入一個(gè)HTML頁(yè)面即可看到效果,將會(huì)有兩次彈出提示,最后在頁(yè)面上顯示YES,表示完成2012-01-01AJAX跨域請(qǐng)求之JSONP獲取JSON數(shù)據(jù)
JSONP(JSON with Padding)是一個(gè)非官方的協(xié)議,它允許在服務(wù)器端集成Script tags返回至客戶端,通過(guò)javascript callback的形式實(shí)現(xiàn)跨域訪問(wèn)(這僅僅是JSONP簡(jiǎn)單的實(shí)現(xiàn)形式)。2015-09-09Ajax讀取數(shù)據(jù)到表格的實(shí)現(xiàn)代碼
前兩篇我們講了 ajax開始的準(zhǔn)備 與及如何使用ajax技術(shù)進(jìn)行簡(jiǎn)單的數(shù)據(jù)讀?。?/div> 2010-10-10AngularJS tab欄實(shí)現(xiàn)和mvc小案例實(shí)例詳解
這篇文章主要介紹了angularJS tab欄實(shí)現(xiàn)和mvc小案例,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2017-05-05最新評(píng)論