標籤:style http color io os 使用 ar strong for
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.readyState);
alert(textStatus);
},
擴充閱讀:
通過XMLHttpRequest對象向伺服器發送請求。
onreadystatechange事件處理函數,它處理來自伺服器的觸發,而不是處理由使用者引起的觸發。每當readystatechange事件觸發它就執行,而readystatechange事件都是由伺服器觸發的。每當readyState屬性改變,那麼onreadystatechange就被觸發
var request = getHTTPObject();
if (request) {
request.onreadystatechange = doSomething;
}
這裡注意:doSomething不要括弧。表明是函數,加上括弧表明是函數執行的結果。doSomethiing是自己編寫的函數。
readyState
他包括四個狀態:
0 為初始化——open函數還沒調用。
1 正在載入——open函數已調用,但send函數沒有調用。
2 已載入 ——send函數已調用。
3 正在互動——伺服器正在發送響應。
4 完成 ——伺服器完成發送響應。
實際中,不是那麼的狀態,你可以簡單使用:
function doSomething() {
if (request.readyState == 4) {
// do something with the response
}
}
儘管每次onreadystatechage被伺服器觸發,但是只有readyState==4的時候才執行代碼
status
瀏覽器在發送請求時,伺服器在發送響應時都會發送headers,headers包括文檔資訊:
文件類型content type (HTML, XML, and so on)
字元編碼 (utf-8, iso-8859-1, and so on).
在伺服器發送的響應中最重要的是status code:
404:“Not Found”
403:“Forbidden”
500:“Internal Server Error”
200:“OK”這個最常用
304:“Not Modified”
function doSomething() {
if (request.readyState == 4) {
if (request.status == 200) {
// 表明伺服器發送響應成功
}
}
}
opera瀏覽器有時返回304,所以下面的代碼改進
function doSomething() {
if (request.readyState == 4) {
if (request.status == 200 || request.status == 304) {
}
}
}
ajax 事件使用