PHP and AJAX Live Search

AJAX magbibigay ng mas maliwanag at mas interaktibong karanasan sa paghahanap sa mga user.

AJAX Live Search

在下面的 AJAX 例子中,我们将演示一个实时的搜索。

实时的搜索与传统搜索相比,具有很多优势:

  • 当键入数据时,就会显示出匹配的结果
  • 当继续键入数据时,对结果进行过滤
  • 如果结果太少,删除字符就可以获得更宽的范围

在下面的文本框中搜索 CodeW3C.com 的页面

本例包括四个元素:

  • 简单的 HTML 表单
  • JavaScript
  • PHP page
  • XML 文档

在本例中,结果在一个 XML 文档 (links.xml) 中进行查找。为了让这个例子小而简单,我们只提供 8 个结果。

HTML 表单

这是 HTML 页面。它包含一个简单的 HTML 表单,针对此表单的 CSS 样式,以及指向 JavaScript 的链接:

<html>
<head>
<script src="livesearch.js"></script> 
<style type="text/css"> 
#livesearch
  { 
  margin:0px;
  width:194px; 
  }
#txt1
  { 
  margin:0px;
  } 
</style>
</head>
<body>
<form>
<input type="text" id="txt1" size="30"
onkeyup="showResult(this.value)">
<div id="livesearch"></div>
</form>
</body>
</html>

例子解释 - HTML 表单

正如你看到的,HTML 页面包含一个简单的 HTML 表单,其中的文本框名为 "txt1"。

表单是这样工作的:

  1. 当用户在文本框中按键并松开按键时,会触发一个事件
  2. 当事件触发时,会执行名为 showResult() 的函数
  3. 表单下面是名为 "livesearch" 的 <div> 元素。它用作 showResult() 所返回数据的占位符

JavaScript

JavaScript 代码存储在与 HTML 文档连接的 "livesearch.js" 中:

var xmlHttp
function showResult(str)
{
if (str.length==0)
 { 
 document.getElementById("livesearch").
 innerHTML="";
 document.getElementById("livesearch").
 style.border="0px";
 ibabalik;
 }
xmlHttp=GetXmlHttpObject()
kung (xmlHttp==null)
 {
 alert ("Browser does not support HTTP Request")
 ibabalik;
 }
var url="livesearch.php"
url=url+"?q="+str;
url=url+"&sid="+Math.random();
xmlHttp.onreadystatechange=stateChanged; 
xmlHttp.open("GET",url,true);
xmlHttp.send(null);
} 
function stateChanged() 
{ 
kung (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
 { 
 document.getElementById("livesearch").
 innerHTML=xmlHttp.responseText;
 document.getElementById("livesearch").
 style.border="1px solid #A5ACB2";
 } 
}
function GetXmlHttpObject()
{
var xmlHttp=null;
sa try
 {
 // Firefox, Opera 8.0+, Safari
 xmlHttp=new XMLHttpRequest();
 }
sa catch (e)
 {
 // Internet Explorer
 sa try
  {
  xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
  }
 sa catch (e)
  {
  xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
 }
ibabalik ang xmlHttp;
}

Example Explanation:

GetXmlHttpObject at PHP and AJAX Requests ay katulad ng halimbawa.

Function na showResult()

Ang function ay magsasagawa sa bawat pagipasok ng isang character sa text box

Kung walang input ang text field (str.length == 0), ang function ay magtatakbo ng ibabaw na field bilang walang laman at magtanggal ng anumang border na nasa paligid

Gayunpaman, kung mayroong input sa text field, ang function ay magsasagawa ng:

  1. Tukuyin ang url (pangalan ng file) na ipapadala sa server
  2. Magdagdag ng argumento na may nilalaman ng input box (q) sa url
  3. Magdagdag ng isang random number upang maiwasan na gamitin ng server ang file na naka-cache
  4. Tinutukoy ang function na GetXmlHttpObject upang lumikha ng XMLHTTP object at ipaalam sa function na ito na magsagawa ng function na may pangalang stateChanged kapag nagkaroon ng pagbabago
  5. Gamitin ang ibinigay na url upang buksan ang XMLHTTP object
  6. Magpadala ng HTTP request sa server

stateChanged() function

Bukas ang function ay gagawin kapag nagbabago ang estado ng XMLHTTP object.

Kapag ang estado ay naging 4 (o "complete") ay maglalagay ng teksto ng responsen sa placeholder na txtHint at mag-set ng border sa paligid ng mga return field.

PHP page

Ang server page na tinatawag na "livesearch.php" ay tinatawag ng JavaScript code.

"livesearch.php" ng code ay nagcheck sa XML document "links.xml". Ang dokumento na ito ay may mga titulo at URL ng ilang pahina sa codew3c.com.

Ang mga ito ng code ay maghahanap ng mga titulo na tumutugma sa teksto ng paghahanap sa XML file at ibabalik ang resulta bilang HTML:

<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("links.xml");
$x=$xmlDoc->getElementsByTagName('link');
//hanapin ang parameter ng q mula sa URL
$q=$_GET["q"];
//hanapin ang lahat ng links mula sa xml file kapag haba ng q>0
kung (strlen($q) > 0)
{
$hint="";
para ($i=0; $i<($x->length); $i++)
 {
 $y=$x->item($i)->getElementsByTagName('title');
 $z=$x->item($i)->getElementsByTagName('url');
 kung ($y->item(0)->nodeType==1)
  {
  //mahanap ang isang link na tumutugma sa teksto ng paghahanap
  kung (stristr($y->item(0)->childNodes->item(0)->nodeValue,$q))
   {
   kung ($hint=="")
    {
    $hint="<a href='" . 
    $z->item(0)->childNodes->item(0)->nodeValue . 
    "' target='_blank'>" . 
    $y->item(0)->childNodes->item(0)->nodeValue . "</a>";
    }
   else
    {
    $hint=$hint . "<br /><a href='" . 
    $z->item(0)->childNodes->item(0)->nodeValue . 
    "' target='_blank'>" . 
    $y->item(0)->childNodes->item(0)->nodeValue . "</a>";
    }
   }
  }
 }
}
//Set output to "no suggestion" if no hint were found
//Or to the correct values
if ($hint == "")
 {
 $response="no suggestion";
 }
else
 {
 $response=$hint;
 }
//Output the response
echo $response;
?>

Example Explanation:

If any text is sent from JavaScript (strlen($q) > 0), the following will occur:

  1. PHP creates an XML DOM object for the "links.xml" file
  2. Traverse all "title" elements (nodetypes = 1) to find the match for the name passed by JavaScript
  3. Find the link containing the correct title and set it to the "$response" variable. If more than one match is found, all matches will be added to the variable
  4. If no match is found, set the $response variable to "no suggestion"
  5. $result is the output sent to the "livesearch" placeholder