Ajax原來這麼簡單(屬性用法詳解)
在專案的的日常開發中免不了會有表單提交的功能,但是對於我來說有的時候會有一部分ajax的屬性記不太清。今天在這裡總結一下。
url:
為String型別的字串引數,為傳送請求的地址,預設訪問地址為當前頁面地址。
type:
要求引數的型別為String,其請求方式有兩種(post/get)預設為get請求。注意其他http請求方法,例如put和delete也可以使用,但有一部分瀏覽器不支援這種請求方法。
timeout:
要求引數的型別為Number,請求的超時時間單位為(毫秒)。該引數可以覆蓋$.ajaxSetup()方法的全域性設定。
async:
要求的引數為Boolean型別,預設值為true,所有請求均為非同步請求。當需要傳送同步請求,將true設定為false。同步請求需要當一個請求執行完成下一個請求才可以執行。
cache:
同樣要求的引數為Boolean型別,預設值為true,當預設值為true的時候遇到載入資訊會優先從瀏覽器快取中載入請求資訊。如果預設值為flase將不會從瀏覽器快取中載入請求資訊。
data:
要求的引數為Object或String型別,不管傳送的是什麼型別的引數,都會被自動轉換為字串格式。get請求中將附加在url後。防止這種自動轉換。
processData:
物件的格式必須為key/value,例如:{foo1:“bar1”,foo2:“bar2”}轉換為&foo1=bar1&foo2=bar2。如果是陣列,例如:{foo:[“bar1”,“bar2”]}轉換為&foo=bar1&foo=bar2。
dataType:
要求引數為String型別,JQuery將自動根據http包mime資訊返回responseXML或responseText,並作為回撥函式引數傳遞。如下所示:
xml:返回XML文件,可用JQuery處理。
html:返回純文字HTML資訊;包含的script標籤會在插入DOM時執行。
script:返回純文字JavaScript程式碼。不會自動快取結果。除非設定了cache引數。注意在遠端請求時(不在同一個域下),所有post請求都將轉為get請求。
json:返回JSON資料。
jsonp:JSONP格式。使用SONP形式呼叫函式時,例如myurl?callback=?,JQuery將自動替換後一個“?”為正確的函式名,以執行回撥函式。
text:返回純文字字串。
8.beforeSend:
要求的引數為Function型別,傳送請求前可以修改XMLHttpRequest物件的函式,新增自定義HTTP協議的頭。在beforeSend中如果返回false可以取消本次ajax請求。XMLHttpRequest物件是惟一的引數。
function(XMLHttpRequest){
this; //呼叫本次ajax請求時傳遞的options引數
}
complete:
要求為Function型別的引數,請求完成後呼叫的回撥函式(請求成功或失敗時均呼叫)。引數:XMLHttpRequest物件和一個描述成功請求型別的字串。
function(XMLHttpRequest, textStatus){
this; //呼叫本次ajax請求時傳遞的options引數
}
success:要求為Function型別的引數,請求成功後呼叫的回撥函式,有兩個引數。
(1)由伺服器返回,並根據dataType引數進行處理後的資料。
(2)描述狀態的字串。
function(data, textStatus){
//data可能是xmlDoc、jsonObj、html、text等等
this; //呼叫本次ajax請求時傳遞的options引數
}
error:
要求為Function型別的引數,請求失敗時被呼叫的函式。該函式有3個引數,即XMLHttpRequest物件、錯誤資訊、捕獲的錯誤物件(可選)。ajax事件函式如下:
function(XMLHttpRequest, textStatus, errorThrown){
//通常情況下textStatus和errorThrown只有其中一個包含資訊
this; //呼叫本次ajax請求時傳遞的options引數
}
contentType:
要求為String型別的引數,當傳送資訊至伺服器時,內容編碼型別預設為"application/x-www-form-urlencoded"。該預設值適合大多數應用場合。
當傳送的資料格式為json時,設定的編碼型別為:“application/json; charset=utf-8”
dataFilter:
要求為Function型別的引數,給Ajax返回的原始資料進行預處理的函式。提供data和type兩個引數。data是Ajax返回的原始資料,type是呼叫jQuery.ajax時提供的dataType引數。函式返回的值將由jQuery進一步處理。
function(data, type){
//返回處理後的資料
return data;
}
dataFilter:
要求為Function型別的引數,給Ajax返回的原始資料進行預處理的函式。提供data和type兩個引數。data是Ajax返回的原始資料,type是呼叫jQuery.ajax時提供的dataType引數。函式返回的值將由jQuery進一步處理。
function(data, type){
//返回處理後的資料
return data;
}
global:
要求為Boolean型別的引數,預設為true。表示是否觸發全域性ajax事件。設定為false將不會觸發全域性ajax事件,ajaxStart或ajaxStop可用於控制各種ajax事件。
ifModified:
要求為Boolean型別的引數,預設為false。僅在伺服器資料改變時獲取新資料。伺服器資料改變判斷的依據是Last-Modified頭資訊。預設值是false,即忽略頭資訊。
jsonp:
要求為String型別的引數,在一個jsonp請求中重寫回調函式的名字。該值用來替代在"callback=?“這種GET或POST請求中URL引數裡的"callback"部分,例如{jsonp:‘onJsonPLoad’}會導致將"onJsonPLoad=?“傳給伺服器。
username:
要求為String型別的引數,用於響應HTTP訪問認證請求的使用者名稱。
password:
要求為String型別的引數,用於響應HTTP訪問認證請求的密碼。
processData:
要求為Boolean型別的引數,預設為true。預設情況下,傳送的資料將被轉換為物件(從技術角度來講並非字串)以配合預設內容型別"application/x-www-form-urlencoded”。如果要傳送DOM樹資訊或者其他不希望轉換的資訊,請設定為false。
scriptCharset:
要求為String型別的引數,只有當請求時dataType為"jsonp"或者"script”,並且type是GET時才會用於強制修改字符集(charset)。通常在本地和遠端的內容編碼不同時使用。
$.each()函式:
.each()示例如下:
var json = ‘[{“id”:“1”,“tagName”:“apple”},{“id”:“2”,“tagName”:“orange”},
{“id”:“3”,“tagName”:“banana”},{“id”:“4”,“tagName”:“watermelon”},
{“id”:“5”,“tagName”:“pineapple”}]’;
$.each(json, function(idx, obj) {
alert(obj.tagName);
});
Jquery物件的each()方法如下:
$(“button”).click(function(){
KaTeX parse error: Expected '}', got 'EOF' at end of input: … alert((this).text())
});
});
備註:function(index,element)
index - 選擇器的 index 位置
element - 當前的元素(也可使用 “this” 選擇器)