您好,欢迎访问一九零五行业门户网

php怎么实现类似百度搜索功能

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代码
<?phpfunction 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怎么实现类似百度搜索功能的详细内容。
其它类似信息

推荐信息