jQuery ajax - post() metod

Exempel

Förfråga till webbsidan test.php, ignorera returvärdet:

$.post("test.php");

TIY-exempel

Ändra texten på div-elementet genom AJAX POST-förfrågan:

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

Prova själv

Definition och användning

post() metoden laddar data från servern via HTTP POST-förfrågan.

Syntaks

jQuery.post(url,data,success(data, textStatus, jqXHR),dataType)
Parameter Beskrivning
url Obligatorisk. Bestäm till vilken URL förfrågan ska skickas.
data Valfritt. Mapp eller strängvärde. Bestäm data som skickas tillsammans med förfrågan till servern.
success(data, textStatus, jqXHR) Valfritt. Kall-back-funktion som körs när förfrågan är framgångsrik.
dataType

Valfritt. Bestäm den förväntade datatypen för serverns respons.

Standard är att göra en intelligent bedömning (xml, json, script eller html).

Detaljerad förklaring

Denna funktion är en förenklad Ajax-funktion, ekvivalent med:

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

Baserat på de olika MIME-typerna i svaret, varierar de data som skickas till success-kall-back-funktionen, dessa data kan vara XML-element, textsträng, JavaScript-fil eller JSON-objekt. Man kan också skicka till success-kall-back-funktionen den textstatus som är responsen.

För jQuery 1.5 kan man också skicka till success-kall-back-funktionen: jqXHR 对象(jQuery 1.4 中传递的是 XMLHttpRequest 对象)。

De flesta implementeringar bestämmer en success-funktion:

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

本例读取被请求的 HTML 片段,并插入页面中。

通过 POST 读取的页面不被缓存,因此 jQuery.ajaxSetup() 中的 cache 和 ifModified 选项不会影响这些请求。

注释:由于浏览器安全方面的限制,大多数 "Ajax" 请求遵守同源策略;请求无法从不同的域、子域或协议成功地取回数据。

注释:如果由 jQuery.post() 发起的请求返回错误代码,那么不会有任何提示,除非脚本已调用了全局的 .ajaxError() 方法。或者对于 jQuery 1.5,jQuery.post() 返回的 jqXHR 对象的 .error() 方法也可以用于错误处理。

jqXHR 对象

对于 jQuery 1.5,所有 jQuery 的 AJAX 方法返回的是 XMLHTTPRequest 对象的超集。由 $.post() 返回的 jQuery XHR 对象或 "jqXHR,"实现了约定的接口,赋予其所有的属性、方法,以及约定的行为。出于对由 $.ajax() 使用的回调函数名称便利性和一致性的考虑,它提供了 .error(), .success() 以及 .complete() 方法。这些方法使用请求终止时调用的函数参数,该函数接受与对应命名的 $.ajax() 回调函数相同的参数。

jQuery 1.5 中的约定接口同样允许 jQuery 的 Ajax 方法,包括 $.post(),来链接同一请求的多个 .success()、.complete() 以及 .error() 回调函数,甚至会在请求也许已经完成后分配这些回调函数。

// 请求生成后立即分配处理程序,请记住该请求针对 jqxhr 对象
    var jqxhr = $.post("example.php", function() {
      alert("success");
    })
    .success(function() { alert("second success"); })
    .error(function() { alert("error"); })
    .complete(function() { alert("complete"); });
    // Utför andra uppgifter här
    // Sätt en annan completionsfunktion för den ovanstående förfrågan
    jqxhr.complete(function(){ alert("second complete"); });

Mer exempel

Exempel 1

Förfråga sidan test.php och skicka några extra data tillsammans (medan man fortfarande ignorerar returvärdet):

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

Exempel 2

Skicka dataarray till servern (medan man fortfarande ignorerar returvärdet):

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

Exempel 3

Skicka formulärdata med hjälp av en AJAX-forespurg:

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

Exempel 4

Skriv ut resultatet från den efterfrågade sidan test.php (HTML eller XML beroende på det returnerade innehållet):

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

Exempel 5

Skicka data till sidan test.php och skriv ut resultatet (HTML eller XML beroende på det returnerade innehållet):

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

Exempel 6

Få innehållet från sidan test.php och lagra det som en XMLHttpResponse-objekt, och behandla det med JavaScript-funktionen process():

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

Exempel 7

Få innehållet i json-format från sidan test.php:

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