温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2023-03-22 14:11:03 来源:亿速云 阅读:90 作者:iii 栏目:编程语言

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

一、实现原理

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

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

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

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

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

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

二、实现步骤

  1. 建立数据库表

我们先建立一个名为 products 的商品表,包含以下字段:

id          int(11)         商品 ID
name        varchar(255)    商品名称
description text            商品描述
price       decimal(10,2)   商品价格

  1. 编写数据库查询函数

我们需要编写一个 query() 函数去连接数据库并执行查询,返回结果数组。示例如下:

<?php
function 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);
}
?>

  1. 编写搜索提示框逻辑

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

<?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 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实现一个搜索提示框”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

php
AI