ajax實戰用法詳解

謙虛令人進步,總結令人提升!php

如下5個方法執行通常Ajax請求的簡短形式,在處理複雜的Ajax請求時應該使用jQuery.ajax()html

1.load(url,[data],[callback])
載入遠程HTML文件代碼並插入至DOM中,默認使用GET方式,傳遞參數時自動轉換爲POST方式。python

示例代碼以下:
//無參數、無回調函數
$("#showload").load("load.htm");
//無回調函數
$("#showload").load("load.htm", { "para": "para-value" });
$("#showload").load("load.htm", { "para": "para-value" },
function() {
//處理
})

2.jQuery.get(url, [data], [callback])
使用get方式從服務器端獲取數據。jquery

$.get("jqueryget.htm", { "id": this.id },
function(req) {
//成功時的回調方法
$("#showget").html(req);
});
})ajax

3.jQuery.post(url, [data], [callback])
使用POST方式來進行異步請求。同jQuery.get()相比,差異在於請求的方式,因此這裏不作特別的說明了,使用方法同jQuery.get()類似。json

4.jQuery.getScript(url,[callback])
經過 GET 方式請求載入並執行一個JavaScript文件。這個技術在前邊文章中已經提到過,也是jQuery.ajax的一種簡單的使用方法,能夠看看ajax加載js,因此在這裏也不作特別的說明了。api

5.jQuery.getJSON(url,[data],[callback])
經過get方式獲取json格式的數據。數組

示例代碼以下:
$.getJSON("http://api.baidu.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=?", function(req) {
$.each(req.items, function(i, item) {
if (i == vnum) {
$("<img src="" + item.media.m + "" title="" + item.title + "" />").appendTo("#showjson");
}
});
});瀏覽器

6.jQuery.ajax()
使用jQuery.ajax()方法獲取數據,下邊給個經常使用寫法,並作了相應的註釋。
//代碼以下
$.ajax({
url: "http://www.cnblogs.com", //請求的url地址
dataType: "json", //返回格式爲json
async: true, //請求是否異步,默認爲異步,這也是ajax重要特性
data: { "id": "value" }, //參數值
type: "GET", //請求方式
beforeSend: function() {
//請求前的處理
},
success: function(req) {
//請求成功時處理
},
complete: function() {
//請求完成的處理
},
error: function() {
//請求出錯處理
}
});緩存

實際應用:

<script>
$(document).ready(function() {
    //$("#img").load("/weixin/act/act4.php");
    //$('#myimg').load("http://www.163.com/newsapp/#f=toplogo");
    //jQuery("#clearCac").click(function() {
    jQuery.ajax({
        //url: "/handle/do.php",    
        url: "ajax_act.php?type=user",
        //type用get時要注意緩存,URL+"&"+"t="+Math.random();或new Date();
        type: "post",
        //get去緩存的一個辦法就是 cache:false,而post由於參數不一樣,不會產生緩存問題。
        cache:false,
        //data: { id: '0' },
        data: { "uid":'oZE7SjqjC_A41aGfaj_X8tJDCGEQ'},
        dataType: "json",
        //防止亂碼是須要加上 charset=UTF-8 或別的編碼
        contentType: "application/x-www-form-urlencoded; charset=UTF-8",
        //請求前的處理。
        beforeSend:function(){
            //alert("before:show loading");
            },
        //請求成功時處理。注意鏈接成功纔會有返回值
        success: function(msg) {
            //alert("msg:"+msg);
            $('#msg').html(msg);
        },
        //請求出錯處理。注意:有差錯時才執行程序體,纔會出現alert彈框
        error: function(XMLHttpRequest, textStatus, errorThrown) {
            //若是沒有url中的文件,會報404-未找到
            //alert("status:"+XMLHttpRequest.status);
            //4 - (完成)響應內容解析完成,能夠在客戶端調用了
            //alert("readyState:"+XMLHttpRequest.readyState);
            //若是發生了錯誤,錯誤信息(第二個參數)除了獲得null以外,還多是"timeout", "error", "notmodified" 和 "parsererror"。
            //alert("textStatus:"+textStatus);//error
        },
        //請求完成的處理。不論成功與否,末尾complete都會執行
        complete: function(XMLHttpRequest, textStatus) {
            this; // 調用本次AJAX請求時傳遞的options參數
            alert("complete textStatus:"+textStatus);//error 或  success
            //alert("complete:hide loading");
        }
    });
    });
    //});
</script>

 

 

Jquery中AJAX參數介紹,各個參數各有用法,要完全理解才能用好!
1、error:function (XMLHttpRequest, textStatus, errorThrown)
(默認: 自動判斷 (xml 或 html)) 請求失敗時調用時間。參數有如下三個:XMLHttpRequest 對象、錯誤信息、(可選)捕獲的錯誤對象。

若是發生了錯誤,錯誤信息(第二個參數)除了獲得null以外,還多是"timeout", "error", "notmodified" 和 "parsererror"。
textStatus: "timeout", "error", "notmodified" 和 "parsererror"。
2、error事件返回的第一個參數XMLHttpRequest有一些有用的信息:
XMLHttpRequest.readyState:
狀態碼:
0 - (未初始化)尚未調用send()方法
1 - (載入)已調用send()方法,正在發送請求
2 - (載入完成)send()方法執行完成,已經接收到所有響應內容
3 - (交互)正在解析響應內容
4 - (完成)響應內容解析完成,能夠在客戶端調用了
3、data:"{}", data爲空也必定要傳"{}";否則返回的是xml格式的。並提示parsererror.
4、parsererror的異常和Header 類型也有關係。及編碼header('Content-type: text/html; charset=utf8');
5、XMLHttpRequest.status:略

 

附:Jquery中AJAX參數詳細列表

參數名 類型 描述
url String (默認: 當前頁地址) 發送請求的地址。
type String (默認: "GET") 請求方式 ("POST" 或 "GET"), 默認爲 "GET"。注意:其它 HTTP 請求方法,如 PUT 和 DELETE 也可使用,但僅部分瀏覽器支持。
timeout Number 設置請求超時時間(毫秒)。此設置將覆蓋全局設置。
async Boolean (默認: true) 默認設置下,全部請求均爲異步請求。若是須要發送同步請求,請將此選項設置爲 false。注意,同步請求將鎖住瀏覽器,用戶其它操做必須等待請求完成才能夠執行。
beforeSend Function 發送請求前可修改 XMLHttpRequest 對象的函數,如添加自定義 HTTP 頭。XMLHttpRequest 對象是惟一的參數。
function (XMLHttpRequest) {
this; // the options for this ajax request
}
cache Boolean (默認: true) jQuery 1.2 新功能,設置爲 false 將不會從瀏覽器緩存中加載請求信息。
complete Function 請求完成後回調函數 (請求成功或失敗時均調用)。參數: XMLHttpRequest 對象,成功信息字符串。
function (XMLHttpRequest, textStatus) {
this; // the options for this ajax request
}
contentType String (默認: "application/x-www-form-urlencoded") 發送信息至服務器時內容編碼類型。默認值適合大多數應用場合。
data Object,
String
發 送到服務器的數據。將自動轉換爲請求字符串格式。GET 請求中將附加在 URL 後。查看 processData 選項說明以禁止此自動轉換。必須爲 Key/Value 格式。若是爲數組,jQuery 將自動爲不一樣值對應同一個名稱。如 {foo:["bar1", "bar2"]} 轉換爲 '&foo=bar1&foo=bar2'。
dataType String

預期服務器返回的數據類型。若是不指定,jQuery 將自動根據 HTTP 包 MIME 信息返回 responseXML 或 responseText,並做爲回調函數參數傳遞,可用值:

"xml": 返回 XML 文檔,可用 jQuery 處理。

"html": 返回純文本 HTML 信息;包含 script 元素。

"script": 返回純文本 JavaScript 代碼。不會自動緩存結果。

"json": 返回 JSON 數據 。

"jsonp": JSONP 格式。使用 JSONP 形式調用函數時,如 "myurl?callback=?" jQuery 將自動替換 ? 爲正確的函數名,以執行回調函數。

error Function (默認: 自動判斷 (xml 或 html)) 請求失敗時將調用此方法。這個方法有三個參數:XMLHttpRequest 對象,錯誤信息,(可能)捕獲的錯誤對象。
function (XMLHttpRequest, textStatus, errorThrown) {
// 一般狀況下textStatus和errorThown只有其中一個有值
this; // the options for this ajax request
}
global Boolean (默認: true) 是否觸發全局 AJAX 事件。設置爲 false 將不會觸發全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用於控制不一樣的Ajax事件
ifModified Boolean (默認: false) 僅在服務器數據改變時獲取新數據。使用 HTTP 包 Last-Modified 頭信息判斷。
processData Boolean (默認: true) 默認狀況下,發送的數據將被轉換爲對象(技術上講並不是字符串) 以配合默認內容類型 "application/x-www-form-urlencoded"。若是要發送 DOM 樹信息或其它不但願轉換的信息,請設置爲 false。
success Function 請求成功後回調函數。這個方法有兩個參數:服務器返回數據,返回狀態
function (data, textStatus) {  // data could be xmlDoc, jsonObj, html, text, etc...  this; // the options for this ajax request}
相關文章
相關標籤/搜索