怎么用php实现一个搜索提示框

后端开发   发布日期:2023年10月12日   浏览次数:427

本篇内容主要讲解“怎么用php实现一个搜索提示框”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用php实现一个搜索提示框”吧!

一、实现原理

在 PHP 实现搜索提示框的过程中,我们需要用到 AJAX 技术。主要分为以下几个步骤:

  1. 用户在搜索框中输入搜索关键字。

  2. 把关键字发送给服务器端的 PHP 脚本。

  3. 在服务器端,通过查询数据库或其他数据源,获取与关键字相关的搜索结果。

  4. 将搜索结果封装成 JSON 数据格式并返回给客户端。

  5. 客户端收到服务器返回的数据后,使用 JavaScript 将其展现在搜索框下方,形成搜索提示框。

二、实现步骤

  1. 建立数据库表

我们先建立一个名为

  1. products
的商品表,包含以下字段:

  1. id int(11) 商品 ID
  2. name varchar(255) 商品名称
  3. description text 商品描述
  4. price decimal(10,2) 商品价格
  1. 编写数据库查询函数

我们需要编写一个

  1. query()
函数去连接数据库并执行查询,返回结果数组。示例如下:

  1. <?php
  2. function query($query) {
  3. $database = new PDO('mysql:host=localhost; dbname=database_name', 'database_user', 'database_password');
  4. $database->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  5. $stmt = $database->prepare($query);
  6. $stmt->execute();
  7. return $stmt->fetchAll(PDO::FETCH_ASSOC);
  8. }
  9. ?>
  1. 编写搜索提示框逻辑

实现搜索框提示框逻辑的代码如下:

  1. <?php
  2. $keyword = $_GET['keyword'];
  3. if ($keyword) {
  4. $result = query("SELECT name FROM products WHERE name LIKE '%$keyword%' LIMIT 5");
  5. $data = array();
  6. foreach ($result as $row) {
  7. $data[] = $row['name'];
  8. }
  9. echo json_encode($data);
  10. }
  11. ?>

以上代码执行如下操作:

  • 从 GET 请求中获取搜索关键字。

  • 查询数据库中与关键字匹配的前 5 个商品名称,并将结果保存在

    1. $data
    数组中。
  • 将数据编码成 JSON 格式并返回给客户端。

  • 编写客户端代码

实现搜索框提示框显示的客户端代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>PHP 搜索框提示框实例</title>
  6. <script src="https://cdn.bootcss.com/jquery/3.5.1/jquery.min.js"></script>
  7. </head>
  8. <body>
  9. <input type="text" id="search-box" placeholder="请输入搜索关键字">
  10. <div id="search-result"></div>
  11. <script>
  12. $(document).ready(function() {
  13. $('#search-box').keyup(function() {
  14. var keyword = $(this).val();
  15. $.ajax({
  16. url: 'search.php',
  17. type: 'GET',
  18. dataType: 'json',
  19. data: {keyword: keyword},
  20. success: function(data) {
  21. var html = '';
  22. for (var i = 0; i < data.length; i++) {
  23. html += '<div>' + data[i] + '</div>';
  24. }
  25. $('#search-result').html(html);
  26. },
  27. error: function() {
  28. $('#search-result').html('无法获取数据!');
  29. }
  30. });
  31. });
  32. });
  33. </script>
  34. </body>
  35. </html>

以上代码执行如下操作:

  • 监听搜索框输入事件。

  • 获取搜索框输入关键字并发送 AJAX 请求到

    1. search.php
  • 显示 AJAX 返回的数据在搜索提示框中。

以上就是怎么用php实现一个搜索提示框的详细内容,更多关于怎么用php实现一个搜索提示框的资料请关注九品源码其它相关文章!