PHP - 实现类似于百度的实时搜索

XML文件:


PHP服务端:


$xmlDoc=new DOMDocument();  //创建了一个 DOMDocument-Object实例

$xmlDoc->load("links.xml");  //载入

$link = $xmlDoc->getElementsByTagName('link');  //返回所有link节点的元素

$inputInfo = $_GET["inputInfo"]; // 从 URL 中获取参数inputInfo的值

if (strlen($inputInfo)>0)

{   //从 xml 文件中查找数据

$hint="";

for($i=0; $i<($link->length); $i++)

{   //找到所有的title和url

$title = $link -> item($i) -> getElementsByTagName('title');

$url = $link -> item($i) -> getElementsByTagName('url');

if ($title -> item(0) -> nodeType == 1)   //可以理解为有这个元素

{   // 和输入的值进行匹配

if (stristr($title -> item(0) -> childNodes -> item(0) -> nodeValue, $inputInfo))

{

if ($hint=="")  //为空

{

$hint="<a href='".$url -> item(0) -> childNodes -> item(0) -> nodeValue .
"' target='_blank'>".$title -> item(0) -> childNodes -> item(0) -> nodeValue ."</a>";

} else {

$hint=$hint . "<br/><a href='".
$url -> item(0) -> childNodes -> item(0) -> nodeValue."' target='_blank'>".
$link -> item(0) -> childNodes -> item(0) -> nodeValue ."</a>";

}}}}}

if ($hint==""){

echo "无结果";

}else{

echo $hint;

}


网页端:(这里只贴上js代码)


function showResult(str)

{

if (str.length==0)

{

document.getElementById("livesearch").innerHTML="";

document.getElementById("livesearch").style.border="0px";

return;

}

xmlhttp=new XMLHttpRequest();

xmlhttp.onreadystatechange=function()

{

if (xmlhttp.readyState==4 && xmlhttp.status==200) //state : OK

{   //receive

document.getElementById("livesearch").innerHTML=xmlhttp.responseText;

document.getElementById("livesearch").style.border="1px solid #A5ACB2";

}

}

xmlhttp.open("GET","livesearch.php?inputInfo="+str,true);  //send

xmlhttp.send();

}


<form>

<input type="text" size="30" onkeyup="showResult(this.value)">

<div id="livesearch"></div>

</form>


OK!现在就可以愉快的玩耍了!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本章内容 理解包含不同层次节点的 DOM 使用不同的节点类型 克服浏览器兼容性问题及各种陷阱 DOM 是针对 HT...
    闷油瓶小张阅读 3,957评论 0 1
  • 属于简易版,比较适合没有后台基础的初学者入门,使用Ajax响应php对mysql数据库进行操作,将网站搭建在xam...
    dovlie阅读 4,565评论 0 5
  • DOM DOM内容主要分为四部分: 什么是DOM和节点; 获取节点; 节点操作(3种); 属性操作(3种)。 什么...
    magic_pill阅读 4,231评论 0 1
  • 生活中的精彩无处不在,我们只取最爱的一瓢。 时间,金钱,食物,情感……这些哪有浪费之说,只是我们付出了...
    亮亮呀阅读 2,490评论 0 0
  • 今日聚会,谈及烧的一手好菜的父母一般子女也比较会做饭的话题,一位大姐说到:这就是基因的作用。我笑了笑,心里想:其实...
    波菜苗阅读 1,490评论 0 0

友情链接更多精彩内容