溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

jQuery中ajax post() 方法的使用實(shí)例

發(fā)布時(shí)間:2021-08-04 20:22:11 來源:億速云 閱讀:191 作者:chen 欄目:web開發(fā)

這篇文章主要講解了“jQuery中ajax post() 方法的使用實(shí)例”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“jQuery中ajax post() 方法的使用實(shí)例”吧!

在jquery中的ajax有二個(gè)數(shù)據(jù)發(fā)送模式,一種是get,另一種是post()。

jQuery Ajax 參考手冊

實(shí)例

請求 test.php 網(wǎng)頁,忽略返回值:

$.post("test.php");

TIY 實(shí)例

通過 AJAX POST 請求改變 div 元素的文本:

$("input").keyup(function(){
 txt=$("input").val();
 $.post("demo_ajax_gethint.asp",{suggest:txt},function(result){
 $("span").html(result);
 });
});

親自試一試

定義和用法

post() 方法通過 HTTP POST 請求從服務(wù)器載入數(shù)據(jù)。

語法

jQuery.post(url,data,success(data, textStatus, jqXHR),dataType)

jQuery中ajax post() 方法的使用實(shí)例

詳細(xì)說明

該函數(shù)是簡寫的 Ajax 函數(shù),等價(jià)于:

$.ajax({
 type: 'POST',
 url: url,
 data: data,
 success: success,
 dataType: dataType
});

根據(jù)響應(yīng)的不同的 MIME 類型,傳遞給 success 回調(diào)函數(shù)的返回?cái)?shù)據(jù)也有所不同,這些數(shù)據(jù)可以是 XML 根元素、文本字符串、JavaScript 文件或者 JSON 對象。也可向 success 回調(diào)函數(shù)傳遞響應(yīng)的文本狀態(tài)。

對于 jQuery 1.5,也可以向 success 回調(diào)函數(shù)傳遞 jqXHR 對象(jQuery 1.4 中傳遞的是 XMLHttpRequest 對象)。

大部分實(shí)現(xiàn)會(huì)規(guī)定一個(gè) success 函數(shù):

$.post("ajax/test.html", function(data) {
 $(".result").html(data);
});

本例讀取被請求的 HTML 片段,并插入頁面中。

通過 POST 讀取的頁面不被緩存,因此 jQuery.ajaxSetup() 中的 cache 和 ifModified 選項(xiàng)不會(huì)影響這些請求。

注釋:由于瀏覽器安全方面的限制,大多數(shù) "Ajax" 請求遵守同源策略;請求無法從不同的域、子域或協(xié)議成功地取回?cái)?shù)據(jù)。

注釋:如果由 jQuery.post() 發(fā)起的請求返回錯(cuò)誤代碼,那么不會(huì)有任何提示,除非腳本已調(diào)用了全局的 .ajaxError() 方法。或者對于 jQuery 1.5,jQuery.post() 返回的 jqXHR 對象的 .error() 方法也可以用于錯(cuò)誤處理。

jqXHR 對象

對于 jQuery 1.5,所有 jQuery 的 AJAX 方法返回的是 XMLHTTPRequest 對象的超集。由 $.post() 返回的 jQuery XHR 對象或 "jqXHR,"實(shí)現(xiàn)了約定的接口,賦予其所有的屬性、方法,以及約定的行為。出于對由 $.ajax() 使用的回調(diào)函數(shù)名稱便利性和一致性的考慮,它提供了 .error(), .success() 以及 .complete() 方法。這些方法使用請求終止時(shí)調(diào)用的函數(shù)參數(shù),該函數(shù)接受與對應(yīng)命名的 $.ajax() 回調(diào)函數(shù)相同的參數(shù)。

jQuery 1.5 中的約定接口同樣允許 jQuery 的 Ajax 方法,包括 $.post(),來鏈接同一請求的多個(gè) .success()、.complete() 以及 .error() 回調(diào)函數(shù),甚至?xí)谡埱笠苍S已經(jīng)完成后分配這些回調(diào)函數(shù)。

// 請求生成后立即分配處理程序,請記住該請求針對 jqxhr 對象
 var jqxhr = $.post("example.php", function() {
 alert("success");
 })
 .success(function() { alert("second success"); })
 .error(function() { alert("error"); })
 .complete(function() { alert("complete"); });
 // 在這里執(zhí)行其他任務(wù)
 
 // 為上面的請求設(shè)置另一個(gè)完成函數(shù)
 jqxhr.complete(function(){ alert("second complete"); });

更多實(shí)例

例子 1

請求 test.php 頁面,并一起發(fā)送一些額外的數(shù)據(jù)(同時(shí)仍然忽略返回值):

$.post("test.php", { name: "John", time: "2pm" } );

例子 2

向服務(wù)器傳遞數(shù)據(jù)數(shù)組(同時(shí)仍然忽略返回值):

$.post("test.php", { 'choices[]': ["Jon", "Susan"] });

例子 3

使用 ajax 請求發(fā)送表單數(shù)據(jù):

$.post("test.php", $("#testform").serialize());

例子 4

輸出來自請求頁面 test.php 的結(jié)果(HTML 或 XML,取決于所返回的內(nèi)容):

$.post("test.php", function(data){
 alert("Data Loaded: " + data);
 });

例子 5

向頁面 test.php 發(fā)送數(shù)據(jù),并輸出結(jié)果(HTML 或 XML,取決于所返回的內(nèi)容):

$.post("test.php", { name: "John", time: "2pm" },
 function(data){
 alert("Data Loaded: " + data);
 });

例子 6

獲得 test.php 頁面的內(nèi)容,并存儲(chǔ)為 XMLHttpResponse 對象,并通過 process() 這個(gè) JavaScript 函數(shù)進(jìn)行處理:

$.post("test.php", { name: "John", time: "2pm" },
 function(data){
 process(data);
 }, "xml");

例子 7

獲得 test.php 頁面返回的 json 格式的內(nèi)容:

$.post("test.php", { "func": "getNameAndTime" },
 function(data){
 alert(data.name); // John
 console.log(data.time); // 2pm
 }, "json");

感謝各位的閱讀,以上就是“jQuery中ajax post() 方法的使用實(shí)例”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對jQuery中ajax post() 方法的使用實(shí)例這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI