php檔案與HTML頁面的資料互動
HTML傳送(使用POST傳送)
<!doctype html> <html> <head> <meta charset="utf-8"> <title>無標題文件</title> </head> <body> <div class='search-choose' id='search_choose'> <ul> <li id='search_1' class='search-selected'><a href='#'>dog</a></li> <li id='search_2'><a href='#'>cat</a></li> </ul> </div> <script type='text/javascript'> searchArray = document.getElementsByTagName('li');//獲取名字為’li’的所有標籤項並存入陣列 var writeArray = []; for(var i = 0;i<searchArray.length;i++){ writeArray[i] = searchArray[i].innerText;//獲取標籤內容writeArray = ['dog','cat']; } //使用POST將陣列writeArray傳送到php檔案servertest.php var request = new XMLHttpRequest(); request.open("POST", "servertest.php"); var q = "data=" + writeArray;// q="name"+ value; //傳送內容體由name+value組成,此處name為data,value為writeArray request.setRequestHeader("Content-type","application/x-www-form-urlencoded"); request.send(q); request.onreadystatechange = function() { if (request.readyState===4) { if (request.status===200) { } else { alert("發生錯誤:" + request.status); } } } </script> </body> </html>
註:關鍵操作
var request = new XMLHttpRequest(); request.open("POST", "servertest.php"); var q = "data=" + writeArray;// 生成資訊體q = 「name 「+ value request.setRequestHeader("Content-type","application/x-www-form-urlencoded"); request.send(q); //HTML頁面POST傳送內容後,php通過超全域性變數 $_GET 和 $_POST收集
php接收(使用超全域性變數$_GET 和 $_POST收集)
<?php //設定頁面內容是html編碼格式是utf-8 header("Content-Type: text/plain;charset=utf-8"); //判斷如果是get請求,則執行getMethod();;如果是POST請求,則執行postMethod()。 //$_SERVER是一個超全域性變數,在一個指令碼的全部作用域中都可用,不用使用global關鍵字 if ($_SERVER["REQUEST_METHOD"] == "GET") { getMethod(); } elseif ($_SERVER["REQUEST_METHOD"] == "POST"){ postMethod(); } function searchShow(){ } function postMethod(){ $filename = 'save.txt'; //使用超全域性變數 $_GET 和 $_POST收集name對應的value,如下 $searchWrite = $_POST["data"]; //將獲取的HTML返回內容$searchWrite寫入文件save.txt file_put_contents($filename, $searchWrite); $content = file_get_contents($filename); echo $content; }
註:關鍵操作
searchWrite=searchWrite=_POST["data"];
使用超全域性變數 $_POST收集name對應的value放入$searchWrite,於是得到了HTML頁面傳送的資料,可以用了
HTML頁面通過json獲取php的變數
php傳送(通過echo返回json格式的資料對)
<?php header('Access-Control-Allow-Origin:*'); header('Access-Control-Allow-Methods:POST,GET'); header('Access-Control-Allow-Credentials:true'); header("Content-Type: application/json;charset=utf-8"); if ($_SERVER["REQUEST_METHOD"] == "GET") { getMethod(); } elseif ($_SERVER["REQUEST_METHOD"] == "POST"){ postMethod(); } function getMethod(){ $filename = 'search_save.txt';//假設檔案內容為dog,cat,pig,人 if (file_exists($filename)) { $content = file_get_contents($filename); $pattern = '/[x{4e00}-x{9fa5}_a-zA-Z0-9]+/u'; //[x{4e00}-x{9fa5}_a-zA-Z0-9]匹配中文、下劃線、字母、數位 preg_match_all($pattern, $content, $matches); $searchRead = $matches[0];//通過正規表示式提取儲存列表到$searchRead陣列['dog','cat','pig','人'] $defaultSearch = $searchRead[0]; $result = '{"success":false,"defaultSearch":""}'; if($_GET["data"]){ $result = '{"success":true,"defaultSearch":"'.$defaultSearch.'"}'; } } echo $result;//echo返回json格式化資料對{"success":true,"defaultSearch":"'.$defaultSearch.'"} } functionpostMethod(){ }
註:關鍵操作
$result = '{"success":true,"defaultSearch":"'.$defaultSearch.'"}';//將待返回內容改為json格式 echo $result;//HTML頁面的json部分將從echo的輸出獲取json格式化資料對,因此echo輸出內容需要為json格式
HTML接收(通過GET接收php echo返回的json格式的資料對)
<script type='text/javascript'> $(document).ready(function(){ $.ajax({ type: "GET", url: "default_search.php?data=" + value,//value為HTML向url傳送的內容體,在php中可以通過超全域性變數收集 dataType: "json", //data為php使用echo返回的json格式的資料對,通過data.name的形式即可以使用name對應的value success: function(data) { if (data.success) { alert(data.defaultSearch); } }, error: function(jqXHR){ alert("發生錯誤:" + jqXHR.status); }, }); }); </script>
關鍵操作:
$.ajax({ type: "GET", url: "default_search.php?data=" + "searchArray", dataType: "json", success: function(data) { If(data.success){alert(data.defaultSearch);} //data為php使用echo輸出的json格式的資料對,通過data.name的形式即可以使用name對應的value }, error: function(jqXHR){ alert("發生錯誤:" + jqXHR.status); }, }); });
以上就是html如何與php資料互動的詳細內容,更多請關注TW511.COM其它相關文章!