PHP – AJAX 與 PHP

2021-11-18 09:41 更新

AJAX 被用于創(chuàng)建交互性更強(qiáng)的應(yīng)用程序。


AJAX PHP 實(shí)例

下面的實(shí)例將演示當(dāng)用戶在輸入框中鍵入字符時(shí),網(wǎng)頁(yè)如何與 Web 服務(wù)器進(jìn)行通信:

實(shí)例

嘗試在輸入框中輸入一個(gè)名字,如:Anna:

姓名:

返回值:



實(shí)例解釋 - HTML 頁(yè)面

當(dāng)用戶在上面的輸入框中鍵入字符時(shí),會(huì)執(zhí)行 "showHint()" 函數(shù)。該函數(shù)由 "onkeyup" 事件觸發(fā):

<html>
 <head>
 <script>
 function showHint(str)
 {
 if (str.length==0)
 { 
 document.getElementById("txtHint").innerHTML="";
 return;
 }
 if (window.XMLHttpRequest)
 {// code for IE7+, Firefox, Chrome, Opera, Safari
 xmlhttp=new XMLHttpRequest();
 }
 else
 {// code for IE6, IE5
 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
 }
 xmlhttp.onreadystatechange=function()
 {
 if (xmlhttp.readyState==4 && xmlhttp.status==200)
 {
 document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
 }
 }
 xmlhttp.open("GET","gethint.php?fullname="+str,true);
 xmlhttp.send();
 }
 </script>
 </head>
 <body>

 <p><b>在輸入框中輸入一個(gè)姓名:</b></p>
 <form> 
 姓名: <input type="text" onkeyup="showHint(this.value)">
 </form>
 <p>返回值: <span id="txtHint"></span></p>

 </body>
 </html>

源代碼解釋:

如果輸入框是空的(str.length==0),該函數(shù)會(huì)清空 txtHint 占位符的內(nèi)容,并退出該函數(shù)。

如果輸入框不是空的,那么 showHint() 會(huì)執(zhí)行以下步驟:

  • 創(chuàng)建 XMLHttpRequest 對(duì)象

  • 創(chuàng)建在服務(wù)器響應(yīng)就緒時(shí)執(zhí)行的函數(shù)

  • 向服務(wù)器上的文件發(fā)送請(qǐng)求

  • 請(qǐng)注意添加到 URL 末端的參數(shù)(q)(包含輸入框的內(nèi)容)


PHP 文件

上面這段通過(guò) JavaScript 調(diào)用的服務(wù)器頁(yè)面是名為 "gethint.php" 的 PHP 文件。

"gethint.php" 中的源代碼會(huì)檢查姓名數(shù)組,然后向?yàn)g覽器返回對(duì)應(yīng)的姓名:

<?php
 // 將姓名填充到數(shù)組中
 $a[]="Anna";
 $a[]="Brittany";
 $a[]="Cinderella";
 $a[]="Diana";
 $a[]="Eva";
 $a[]="Fiona";
 $a[]="Gunda";
 $a[]="Hege";
 $a[]="Inga";
 $a[]="Johanna";
 $a[]="Kitty";
 $a[]="Linda";
 $a[]="Nina";
 $a[]="Ophelia";
 $a[]="Petunia";
 $a[]="Amanda";
 $a[]="Raquel";
 $a[]="Cindy";
 $a[]="Doris";
 $a[]="Eve";
 $a[]="Evita";
 $a[]="Sunniva";
 $a[]="Tove";
 $a[]="Unni";
 $a[]="Violet";
 $a[]="Liza";
 $a[]="Elizabeth";
 $a[]="Ellen";
 $a[]="Wenche";
 $a[]="Vicky";

 //從請(qǐng)求URL地址中獲取 q 參數(shù)
 $q=$_GET["q"];

 //查找是否由匹配值, 如果 q>0
 if (strlen($q) > 0)
 {
 $hint="";
 for($i=0; $i<count($a); $i++)
 {
 if (strtolower($q)==strtolower(substr($a[$i],0,strlen($q))))
 {
 if ($hint=="")
 {
 $hint=$a[$i];
 }
 else
 {
 $hint=$hint." , ".$a[$i];
 }
 }
 }
 }

 // 如果沒有匹配值設(shè)置輸出為 "no suggestion" 
 // or to the correct values
 if ($hint == "")
 {
 $response="no suggestion";
 }
 else
 {
 $response=$hint;
 }

 //輸出返回值
 echo $response;
 ?>

解釋:如果 JavaScript 發(fā)送了任何文本(即 strlen($q) > 0),則會(huì)發(fā)生:

  1. 查找匹配 JavaScript 發(fā)送的字符的姓名

  2. 如果未找到匹配,則將響應(yīng)字符串設(shè)置為 "no suggestion"

  3. 如果找到一個(gè)或多個(gè)匹配姓名,則用所有姓名設(shè)置響應(yīng)字符串

  4. 把響應(yīng)發(fā)送到 "txtHint" 占位符

PHP Ajax 跨域問題解決方案

如果你的異步請(qǐng)求需要跨域可以查看:PHP Ajax 跨域問題解決方案。


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

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)