jQuery - AJAX get()/post() 方法
jQuery - AJAX get() 和post() 方法
jQuery get() 和post() 方法用於透過HTTP GET 或POST 請求從伺服器請求資料。
HTTP 請求:GET vs. POST
兩種在客戶端和伺服器端進行請求-回應的常用方法是:GET 和POST。
GET - 從指定的資源請求資料
POST - 向指定的資源提交要處理的資料
GET 基本上用於從伺服器取得(取回)數據。註:GET 方法可能會傳回快取資料。
POST 也可用於從伺服器取得資料。不過,POST 方法不會快取數據,而且常用於連同請求一起發送數據。
如需學習更多有關 GET 和 POST 以及兩種方法差異的知識,請閱讀我們的 HTTP 方法 - GET 對比 POST。
jQuery $.get() 方法
$.get(URL,callback);
必要的 URL 參數規定您想要要求的 URL。 可選的 callback 參數是請求成功後執行的函數名稱。 下面的範例使用$.get() 方法從伺服器上的一個檔案中取回資料:實例
運行實例»點擊"運行實例" 按鈕查看線上實例
$.get() 的第一個參數是我們希望請求的URL("demo_test. php")。 第二個參數是回呼函數。第一個回呼參數存有被請求頁面的內容,第二個回呼參數存有請求的狀態。 提示: 這個 PHP 檔案 ("demo_test.php") 類似這樣:<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>菜鸟教程(runoob.com)</title> <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> </script> <script> $(document).ready(function(){ $("button").click(function(){ $.get("/try/ajax/demo_test.php",function(data,status){ alert("数据: " + data + "\n状态: " + status); }); }); }); </script> </head> <body> <button>发送一个 HTTP GET 请求并获取返回结果</button> </body> </html>
運行實例»點擊"運行實例" 按鈕查看線上實例
<?php
echo '這是個從PHP檔案讀取的資料。 ';
?>
?>
jQuery $.post() 方法
$.post()方法透過HTTP POST 請求從伺服器上請求資料。 語法:$.post(URL,data,callback);
必要的 URL 參數規定您想要要求的 URL。 可選的 data 參數規定連同請求發送的資料。 可選的 callback 參數是請求成功後執行的函數名稱。 下面的範例使用$.post() 連同請求一起傳送資料:實例
執行實例» 點擊"運行實例" 按鈕查看線上實例
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>菜鸟教程(runoob.com)</title> <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> </script> <script> $(document).ready(function(){ $("button").click(function(){ $.post("/try/ajax/demo_test_post.php",{ name:"菜鸟教程", url:"http://www.runoob.com" }, function(data,status){ alert("数据: \n" + data + "\n状态: " + status); }); }); }); </script> </head> <body> <button>发送一个 HTTP POST 请求页面并获取返回内容</button> </body> </html>
執行實例» 點擊"運行實例" 按鈕查看線上實例
$.post() 的第一個參數是我們想要請求的 URL ("demo_test_post.php")。
然後我們連同請求(name 和 city)一起發送資料。
"demo_test_post.php" 中的 PHP 腳本讀取這些參數,對它們進行處理,然後傳回結果。
第三個參數是回呼函數。第一個回呼參數存有被請求頁面的內容,而第二個參數存有請求的狀態。
提示: 這個PHP 檔案("demo_test_post.php") 類似這樣:
<?php
$name = isset($_POST['name']) ? htmlspecialchars($_POST['name']) : '';
$city = isset($_POST['url']) ? htmlspecialchars($_POST['url']) : '';
echo '網址名稱: ' . $name;
echo "\n";
echo 'URL 位址: ' .$city;
?>
$name = isset($_POST['name']) ? htmlspecialchars($_POST['name']) : '';
$city = isset($_POST['url']) ? htmlspecialchars($_POST['url']) : '';
echo '網址名稱: ' . $name;
echo "\n";
echo 'URL 位址: ' .$city;
?>