jQuery ajax - post() -menetelmä
Esimerkki
Pyyntö test.php -sivulle, jätä palautusarvo huomiotta:
$.post("test.php");
TIY-esimerkki
Muuta div-elementin tekstiä AJAX POST -pyynnön avulla:
$("input").keyup(function(){ txt=$("input").val(); $.post("demo_ajax_gethint.asp",{suggest:txt},function(result){ $("span").html(result); }); });
Määritelmä ja käyttö
post() -menetelmä ladataan tietoja palvelimelta HTTP POST -pyynnön avulla.
Syntaksi
jQuery.post(url,data,success(data, textStatus, jqXHR),dataType)
Parametrit | Kuvaus |
---|---|
url | Välttämätön. Määrittää, mihin URL-osoitteeseen pyyntö lähetetään. |
data | Valinnainen. Määrittää tietojoukon tai merkkijonon, joka lähetetään pyynnön mukana. |
success(data, textStatus, jqXHR) | Valinnainen. Suoritettava takaisin kutsumafunktio, kun pyyntö on onnistunut. |
dataType |
Valinnainen. Määrittää odotettu palvelimen vastaustyyppi. Oletuksena suorittaa älykäs arviointi (xml, json, script tai html). |
Yksityiskohtainen selitys
Tämä funktio on lyhennetty Ajax-funktio, joka on yhtä arvokas kuin:
$.ajax({ type: 'POST', url: url, data: data, success: success, dataType: dataType });
Vastaanotetun MIME-tyypin mukaan success-kutsuun välitetty palautustieto voi olla erilainen, nämä tiedot voivat olla XML-elementti, tekstitausta, JavaScript-tiedosto tai JSON-objekti. Voidaan myös välittää success-kutsuun vastausta oleva tekstitila.
jQuery 1.5:ssa voidaan myös välittää success-kutsuun takaisin jqXHR 对象(jQuery 1.4:ssa siirretään XMLHttpRequest-objekti)。
Useimmat toteutukset määrittelevät yhden 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"); }); // Tässä suoritetaan muut tehtävät // Aseta toinen valmis-funktio yllä olevalle pyynnölle jqxhr.complete(function(){ alert("second complete"); });
Lisää esimerkkejä
Esimerkki 1
Pyydä test.php -sivua ja lähetä mukanaan joitakin lisätietoja (samalla jättäen huomiotta palautetun arvon):
$.post("test.php", { name: "Bill", time: "2pm" } );
Esimerkki 2
Lähetä tietoja palvelimelle tietorakenteena (samalla jättäen huomiotta palautetun arvon):
$.post("test.php", { 'choices[]': ["Jon", "Susan"] });
Esimerkki 3
Lähetä lomakkeen tiedot ajax-pyynnöllä:
$.post("test.php", $("#testform").serialize());
Esimerkki 4
Tulosta pyynnön sivulta test.php tulokset (HTML tai XML riippuen palautetusta sisällöstä):
$.post("test.php", function(data){ alert("Data Loaded: " + data); });
Esimerkki 5
Lähetä dataa sivulle test.php ja tulosta tulos (HTML tai XML riippuen palautetusta sisällöstä):
$.post("test.php", { name: "Bill", time: "2pm" }, function(data){ alert("Data Loaded: " + data); });
Esimerkki 6
Saada test.php -sivun sisältö ja tallennetaan XMLHttpResponse-objektiksi, ja käsitellään sitä process() -JavaScript-funktiolla:
$.post("test.php", { name: "Bill", time: "2pm" }, function(data){ process(data); }, "xml");
Esimerkki 7
Saada test.php -sivun palauttama json-muotoinen sisältö:
$.post("test.php", { "func": "getNameAndTime" }, function(data){ alert(data.name); // Bill console.log(data.time); // 2pm }, "json");