怎么用php实现一个搜索提示框
本篇内容主要讲解“怎么用php实现一个搜索提示框”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用php实现一个搜索提示框”吧!
一、实现原理
在 PHP 实现搜索提示框的过程中,我们需要用到 AJAX 技术。主要分为以下几个步骤:
用户在搜索框中输入搜索关键字。
把关键字发送给服务器端的 PHP 脚本。
在服务器端,通过查询数据库或其他数据源,获取与关键字相关的搜索结果。
将搜索结果封装成 JSON 数据格式并返回给客户端。
客户端收到服务器返回的数据后,使用 JavaScript 将其展现在搜索框下方,形成搜索提示框。
二、实现步骤
建立数据库表
我们先建立一个名为 products
的商品表,包含以下字段:
id int(11) 商品 IDname varchar(255) 商品名称description text 商品描述price decimal(10,2) 商品价格
编写数据库查询函数
我们需要编写一个 query()
函数去连接数据库并执行查询,返回结果数组。示例如下:
<?phpfunction query($query) { $database = new PDO('mysql:host=localhost; dbname=database_name', 'database_user', 'database_password'); $database->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $stmt = $database->prepare($query); $stmt->execute(); return $stmt->fetchAll(PDO::FETCH_ASSOC);}?>
编写搜索提示框逻辑
实现搜索框提示框逻辑的代码如下:
<?php$keyword = $_GET['keyword'];if ($keyword) { $result = query("SELECT name FROM products WHERE name LIKE '%$keyword%' LIMIT 5"); $data = array(); foreach ($result as $row) { $data[] = $row['name']; } echo json_encode($data);}?>
以上代码执行如下操作:
从 GET 请求中获取搜索关键字。
查询数据库中与关键字匹配的前 5 个商品名称,并将结果保存在
$data
数组中。将数据编码成 JSON 格式并返回给客户端。
编写客户端代码
实现搜索框提示框显示的客户端代码如下:
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>PHP 搜索框提示框实例</title> <script class="lazy" data-src="https://cdn.bootcss.com/jquery/3.5.1/jquery.min.js"></script></head><body> <input type="text" id="search-box" placeholder="请输入搜索关键字"> <div id="search-result"></div> <script> $(document).ready(function() { $('#search-box').keyup(function() { var keyword = $(this).val(); $.ajax({ url: 'search.php', type: 'GET', dataType: 'json', data: {keyword: keyword}, success: function(data) { var html = ''; for (var i = 0; i < data.length; i++) { html += '<div>' + data[i] + '</div>'; } $('#search-result').html(html); }, error: function() { $('#search-result').html('无法获取数据!'); } }); }); }); </script></body></html>
以上代码执行如下操作:
监听搜索框输入事件。
获取搜索框输入关键字并发送 AJAX 请求到
search.php
。显示 AJAX 返回的数据在搜索提示框中。
到此,相信大家对“怎么用php实现一个搜索提示框”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341