PHP实现类似百度搜索自动完成(代码简单)

一、效果图:

 

 

二、HTML代码

<html lang="en"><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: availableTagssource: "at.php"});});</script></head><body><div class="ui-widget"><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

如果js和css源代码地址找不到,到这里下载

 

总结:以上是结合mysql 和 jquery-ui实现的自动提示,实际上如果数据库数据量较大的情况,整体对数据库开销也比较大。

这样,也可以尝试使用全文检索工具 xunsearch 或 sphinx 来实现。好处是减少了mysql数据库的查询压力,提高了检索速度。

xunSearch的使用:https://blog.csdn.net/m_nanle_xiaobudiu/article/details/81663636

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
由于2D文件自动排版是一个复杂的任务,需要结合图像处理技术和算法来实现,因此这里提供一些代码片段,以供参考: 1. 使用ImageMagick库将PDF转换为图像: ```php // 安装ImageMagick扩展 $im = new \Imagick(); // 读取PDF文件 $im->readImage('example.pdf'); // 将PDF转换为PNG格式 $im->setImageFormat('png'); // 保存图像文件 $im->writeImage('example.png'); ``` 2. 对图像进行预处理: ```php // 读取PNG图像 $im = imagecreatefrompng('example.png'); // 去除噪点 imagefilter($im, IMG_FILTER_SMOOTH, 5); // 调整亮度和对比度 imagefilter($im, IMG_FILTER_BRIGHTNESS, 10); imagefilter($im, IMG_FILTER_CONTRAST, 5); // 保存预处理后的图像文件 imagepng($im, 'example_processed.png'); ``` 3. 使用OCR技术识别文本: ```php // 安装Tesseract OCR库 // 读取PNG图像 $im = imagecreatefrompng('example_processed.png'); // 使用OCR识别文本 $tesseract = new \TesseractOCR(); $text = $tesseract->recognize($im); // 保存识别结果 file_put_contents('example_text.txt', $text); ``` 4. 使用算法自动排版: ```php // 读取文本和图像 $text = file_get_contents('example_text.txt'); $im = imagecreatefrompng('example_processed.png'); // 将文本和图像进行排版 // ... // 保存排版后的图像文件 imagepng($im, 'example_layout.png'); ``` 以上代码片段只是示例代码实现2D文件自动排版需要更加复杂的算法和技术,具体实现方法需要根据实际需求和情况进行调整和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值