php實作類似百度搜尋功能的方法:1、建立HTML文件,並設定js程式碼為“$(function() {$( "#tags" ).autocomplete({...})” ;2、透過php連接資料庫,並透過「function test($keyword) {...}」方法實作輸入框搜尋功能即可。
本教學操作環境:Windows10系統、PHP8.1版、DELL G3電腦
#php怎麼實作類似百度搜尋功能?
PHP實作類似百度搜尋自動完成(程式碼簡單)
一、效果圖:
#
##二、HTML程式碼<html> <head> <meta charset="utf-8"> <title>jQuery UI 自动完成(Autocomplete) - 默认功能</title> <link rel="stylesheet" href="/public/AutoCom/jquery-ui.css"> <script src="/public/AutoCom/jquery-1.91.js"></script> <script src="/public/AutoCom/jquery-ui.js"></script> <script> $(function() { $( "#tags" ).autocomplete({ // source: availableTags source: "at.php" }); }); </script> </head> <body> <div> <label for="tags">标签:</label> <input id="tags" name="tags" > </div> </body> </html>三、PHP程式碼
<?php function test($keyword) { //连接数据库 $dsn = "mysql:dbname=test;host=localhost;"; $db = new PDO($dsn, 'root', 'root'); //查询数据 $result = $db->prepare("select title from article where title like :title"); $result->execute(array('title' => "%" . $keyword . "%")); $data = $result->fetchall(PDO::FETCH_ASSOC); //将二维数组转化为一维数组(自动补全插件要求的是一个一维数组) foreach ($data as $k => $v) { $datas[] = $v['title']; } return $datas; } //获取输入框的内容 //注:jquery-ui的自动补全ajax 当我们输入一个c时,Autocomplete实际发送的请求路径为at.php?term=c $keyword = $_GET['term']; //根据用户输入值查询相关数据 $data = test($keyword); //输出json字符串 echo json_encode($data); //输出查询的结果(json格式输出) ?>備註:HTML部分引入的css,js原始碼:
<!-- 引入jQuery UI的css文件 --> <link href="http://code.jquery.com/ui/1.10.4/themes/ui-darkness/jquery-ui.css" /> <!-- 引入jQuery的js文件 --> <script type="text/javascript" src="http://code.jquery.com/jquery-1.9.1.js" ></script> <!-- 引入jQuery UI的js文件 --> <script type="text/javascript" src="http://code.jquery.com/ui/1.10.4/jquery-ui.js" ></script>文章參考:http://www.365mini.com/page/jquery-ui-autocomplete.htm 更多功能可參考:http://www.runoob.com/jqueryui/example-autocomplete. html總結:以上是結合mysql 和jquery-ui實現的自動提示,實際上如果資料庫資料量較大的情況,整體對資料庫開銷也比較大。這樣,也可以嘗試使用全文檢索工具xunsearch 或sphinx 來實現。好處是減少了mysql資料庫的查詢壓力,提高了檢索速度。推薦學習:《
PHP影片教學》
以上是php怎麼實現類似百度搜尋功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!