jQuery – AJAX get() 和 post() 方法

2021-12-14 13:53 更新

jQuery get() 和 post() 方法用于通過 HTTP GET 或 POST 請求從服務(wù)器請求數(shù)據(jù)。


HTTP 請求:GET vs. POST

兩種在客戶端和服務(wù)器端進(jìn)行請求-響應(yīng)的常用方法是:GET 和 POST。

  • GET - 從指定的資源請求數(shù)據(jù)
  • POST - 向指定的資源提交要處理的數(shù)據(jù)

GET 基本上用于從服務(wù)器獲得(取回)數(shù)據(jù)。注釋:GET 方法可能返回緩存數(shù)據(jù)。

POST 也可用于從服務(wù)器獲取數(shù)據(jù)。不過,POST 方法不會(huì)緩存數(shù)據(jù),并且常用于連同請求一起發(fā)送數(shù)據(jù)。

如需學(xué)習(xí)更多有關(guān) GET 和 POST 以及兩方法差異的知識,請閱讀我們的 HTTP 方法 - GET 對比 POST。


jQuery $.get() 方法

$.get() 方法通過 HTTP GET 請求從服務(wù)器上請求數(shù)據(jù)。

語法:

$.get(URL,callback);

必需的 URL 參數(shù)規(guī)定您希望請求的 URL。

可選的 callback 參數(shù)是請求成功后所執(zhí)行的函數(shù)名。

下面的例子使用 $.get() 方法從服務(wù)器上的一個(gè)文件中取回?cái)?shù)據(jù):

實(shí)例

$("button").click(function(){
  $.get("demo_test.php",function(data,status){
    alert("數(shù)據(jù): " + data + "\n狀態(tài): " + status);
  });
});

嘗試一下 ?

$.get() 的第一個(gè)參數(shù)是我們希望請求的 URL("demo_test.php")。

第二個(gè)參數(shù)是回調(diào)函數(shù)。第一個(gè)回調(diào)參數(shù)存有被請求頁面的內(nèi)容,第二個(gè)回調(diào)參數(shù)存有請求的狀態(tài)。

提示: 這個(gè) PHP 文件 ("demo_test.php") 類似這樣:

<?php
echo "This is some text from an external PHP file.";
?>


jQuery $.post() 方法

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

語法:

$.post(URL,data,callback);

必需的 URL 參數(shù)規(guī)定您希望請求的 URL。

可選的 data 參數(shù)規(guī)定連同請求發(fā)送的數(shù)據(jù)。

可選的 callback 參數(shù)是請求成功后所執(zhí)行的函數(shù)名。

下面的例子使用 $.post() 連同請求一起發(fā)送數(shù)據(jù):

實(shí)例

$("button").click(function(){
  $.post("demo_test_post.html",
  {
    name:"Donald Duck",
    city:"Duckburg"
  },
  function(data,status){
    alert("Data: " + data + "nStatus: " + status);
  });
});

嘗試一下 ?

$.post() 的第一個(gè)參數(shù)是我們希望請求的 URL ("demo_test_post.php")。

然后我們連同請求(name 和 city)一起發(fā)送數(shù)據(jù)。

"demo_test_post.php" 中的 PHP 腳本讀取這些參數(shù),對它們進(jìn)行處理,然后返回結(jié)果。

第三個(gè)參數(shù)是回調(diào)函數(shù)。第一個(gè)回調(diào)參數(shù)存有被請求頁面的內(nèi)容,而第二個(gè)參數(shù)存有請求的狀態(tài)。

提示: 這個(gè) PHP 文件 ("demo_test_post.php") 類似這樣:

<?php
$name = isset($_POST['name']) ? htmlspecialchars($_POST['name']) : '';
$city = isset($_POST['city']) ? htmlspecialchars($_POST['city']) : '';
echo 'Dear ' . $name;
echo 'Hope you live well in ' . $city;
?>

提示:在jQuery中,$.ajax()方法能夠?qū)崿F(xiàn)與load()、$.get()和$.post()方法相同的功能,并且具有更多的作用!

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號