PHP మరియు AJAX లైవ్ సెర్చ్

AJAX అనేది వినియోగదారులకు సులభంగా ఉపయోగించగలిగే మరియు ఎక్కువ పరస్పర ప్రతిస్పందనతో కూడిన శోధన అనుభవాన్ని అందిస్తుంది.

AJAX Live Search

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

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

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

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

本例包括四个元素:

  • 简单的 HTML 表单
  • JavaScript
  • PHP పేజీ
  • 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";
 return
 }
xmlHttp=GetXmlHttpObject()
if (xmlHttp==null)
 {
 alert ("Browser does not support HTTP Request")
 return
 }
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() 
{ 
if (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;
try
 {
 // Firefox, Opera 8.0+, Safari
 xmlHttp=new XMLHttpRequest();
 }
catch (e)
 {
 // Internet Explorer
 try
  {
  xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
  }
 catch (e)
  {
  xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
 }
return xmlHttp;
}

ఉదాహరణ వివరణలు:

GetXmlHttpObject 与 PHP మరియు AJAX రోజెక్ట్స్ 中的例子相同。

showResult() 函数

该函数每当一个字符输入文本框就会执行一次。

如果文本域中没有输入 (str.length == 0),该函数把返回字段设置为空,并删除周围的任何边框。

不过,如果文本域中存在输入,则函数执行:

  1. 定义发送到服务器的 url (文件名)
  2. 把带有输入框内容的参数 (q) 添加到 url
  3. 添加一个随机数,以防止服务器使用缓存文件
  4. 调用 GetXmlHttpObject 函数来创建 XMLHTTP 对象,并在触发一个变化时告知此函数执行名为 stateChanged 的一个函数
  5. ఇచ్చిన యూరిల్ ద్వారా XMLHTTP పాయింట్ తెరుస్తారు
  6. సర్వర్కు HTTP రెక్వెస్ట్ పంపుతుంది

stateChanged() ఫంక్షన్

ఎక్సిమ్హెచ్ట్ పాయింట్ స్టేట్ మారితే ఈ ఫంక్షన్ పని చేస్తుంది.

స్టేట్ చేసినప్పుడు 4 (లేదా "complete") అయితే, రెస్పాంస్ టెక్స్ట్ ను తొలగించి టెక్స్ట్ హింట్ ప్లేస్ హోల్డర్ నిండిస్తారు మరియు తిరిగి ఫీల్డ్ చుట్టూ కింది కాంటర్న్ సెట్ చేస్తారు.

PHP పేజీ

జావాస్క్రిప్ట్ కోడు కాల్చే సర్వర్ పేజీ "livesearch.php" ఫైలు.

"livesearch.php" లో కోడు ఆ ఎక్సిమ్ ఫైల్ "links.xml" ని పరిశీలిస్తుంది. ఈ ఫైలు codew3c.com పేజీల పేరులు మరియు URL‌లను కలిగి ఉంటుంది.

ఈ కోడు ఎక్సిమ్ ఫైల్‌లో కనుగొనే అనుసరణ పదం పేరులను శోధిస్తుంది మరియు హెచ్చి టెక్స్ట్ ను తిరిగి అందిస్తుంది:

<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("links.xml");
$x=$xmlDoc->getElementsByTagName('link');
//get the q parameter from URL
$q=$_GET["q"];
//lookup all links from the xml file if length of q>0
if (strlen($q) > 0)
{
$hint="";
for($i=0; $i<($x->length); $i++)
 {
 $y=$x->item($i)->getElementsByTagName('title');
 $z=$x->item($i)->getElementsByTagName('url');
 if ($y->item(0)->nodeType==1)
  {
  //find a link matching the search text
  if (stristr($y->item(0)->childNodes->item(0)->nodeValue,$q))
   {
   if ($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>";
    }
   }
  }
 }
}
// ఏ సరిహద్దు కనుగొనబడలేకపోతే అవుట్పుట్ ను "no suggestion" గా నిర్ధారించు
// లేకపోతే సరిహద్దులను సరిహద్దులు గా నిర్ధారించు
if ($hint == "")
 {
 $response="no suggestion";
 }
else
 {
 $response=$hint;
 }
// అవుట్పుట్ ప్రతిస్పందనను ప్రదర్శించు
echo $response;
?>

ఉదాహరణ వివరణలు:

జావాస్క్రిప్ట్ నుండి ఏదైనా టెక్స్ట్ పంపబడినప్పుడు (strlen($q) > 0), జరుగుతుంది:

  1. PHP కోసం "links.xml" ఫైల్ ఒక XML DOM ఆబ్జెక్ట్ సృష్టించడం
  2. అన్ని "title" ఎలమెంట్స్ ను పరిశీలించడం (nodetypes = 1), జావాస్క్రిప్ట్ పంపబడిన డాటా పేరును కనుగొనేందుకు
  3. సరిహద్దులు కనుగొనబడిన లింకులు, సరిహద్దులు కనుగొనబడిన పేరులు అన్నిటినీ వ్యవస్థాపకిని జోడించబడతాయి
  4. ఏ సరిహద్దు కనుగొనబడలేకపోతే, $response వ్యవస్థాపకిని "no suggestion" గా నిర్ధారించబడుతుంది
  5. $result అనేది "livesearch" ప్లేస్ హోల్డర్ కు పంపబడే అవుట్పుట్