0

0

基于PHP和GET参数实现HTML表格数据动态筛选教程

霞舞

霞舞

发布时间:2025-08-30 21:28:15

|

1141人浏览过

|

来源于php中文网

原创

基于PHP和GET参数实现HTML表格数据动态筛选教程

本文将指导如何使用PHP和GET参数,实现HTML表格中数据库数据的动态筛选。通过在页面上设置筛选按钮,用户可以根据特定状态(如在线、离线)来实时刷新并显示相应的数据行,有效管理和展示大量信息。

在web应用中,展示来自数据库的大量数据并提供筛选功能是常见的需求。当用户需要根据特定条件(例如员工状态、订单状态等)查看数据时,动态筛选功能可以极大地提升用户体验和数据可读性。本教程将介绍一种利用phphtml get参数进行服务器端数据筛选的方法,实现点击按钮后隐藏/显示特定状态的表格行。

1. 构建筛选控制按钮

首先,我们需要在HTML页面上创建一组按钮,每个按钮代表一个筛选条件(例如“在线”、“离线”、“已断开连接”)。这些按钮将通过URL的GET参数向服务器传递筛选值。

<div class="filter-buttons">
    <a href="?status=Online" class="btn">在线</a>
    <a href="?status=Offline" class="btn">离线</a>
    <a href="?status=Disconnected" class="btn">已断开</a>
    <a href="?" class="btn">全部</a> <!-- 添加一个“全部”按钮以显示所有数据 -->
</div>

说明:

立即学习PHP免费学习笔记(深入)”;

有道智云AI开放平台
有道智云AI开放平台

有道智云AI开放平台

下载

2. PHP后端数据查询逻辑

在PHP脚本中,我们需要根据URL中是否存在status参数来动态构建SQL查询语句。

<?php
require 'CMS/processing/conn.php'; // 引入数据库连接文件

// 初始化SQL查询语句
$sql = "SELECT * FROM agents";

// 检查是否存在GET参数'status'
if (isset($_GET['status']) && !empty($_GET['status'])) {
    $status = $_GET['status'];
    // 注意:直接拼接GET参数存在SQL注入风险,实际项目中应使用预处理语句
    $sql .= " WHERE agentStatus = '" . mysqli_real_escape_string($con, $status) . "'";
}

$result = mysqli_query($con, $sql);

// 检查查询是否成功
if (!$result) {
    die('查询失败: ' . mysqli_error($con));
}
?>

说明:

立即学习PHP免费学习笔记(深入)”;

  • isset($_GET['status']) && !empty($_GET['status']):这行代码检查URL中是否存在名为status的GET参数,并且其值不为空。
  • $sql .= " WHERE agentStatus = '" . mysqli_real_escape_string($con, $status) . "'";:如果status参数存在,则将WHERE子句添加到SQL查询中,以筛选出匹配特定状态的数据。
  • mysqli_real_escape_string($con, $status):这是一个重要的安全措施,用于转义字符串中的特殊字符,以防止SQL注入攻击。尽管如此,强烈建议在生产环境中使用预处理语句(Prepared Statements)来彻底防范SQL注入

3. HTML表格渲染与数据展示

最后,我们将筛选后的数据通过PHP循环渲染到HTML表格中。

<table id="main_table">
    <thead>
        <tr>
            <th>Id</th>
            <th>Agent Name</th>
            <th>Agent Rank</th>
            <th>Agent Location</th>
            <th>Status</th>
        </tr>
    </thead>
    <tbody>
        <?php
        while ($info = mysqli_fetch_array($result)) {
        ?>
        <tr>
            <td><?php echo htmlspecialchars($info['id']); ?></td>
            <td><?php echo htmlspecialchars($info['agentName']); ?></td>
            <td><?php echo htmlspecialchars($info['agentRank']); ?></td>
            <td><?php echo htmlspecialchars($info['locationNames']); ?></td>
            <td><?php echo htmlspecialchars($info['agentStatus']); ?></td>
        </tr>
        <?php
        }
        ?>
    </tbody>
</table>

说明:

立即学习PHP免费学习笔记(深入)”;

  • while ($info = mysqli_fetch_array($result)):遍历$result中的每一行数据。
  • echo htmlspecialchars($info['column_name']);:使用htmlspecialchars函数对输出的数据进行编码,防止跨站脚本攻击(XSS)。

4. 完整示例代码

将以上所有部分整合,形成一个完整的PHP文件(例如index.php):

<?php
require 'CMS/processing/conn.php'; // 确保这个路径正确指向你的数据库连接文件

// 初始化SQL查询语句
$sql = "SELECT * FROM agents";

// 检查是否存在GET参数'status'
if (isset($_GET['status']) && !empty($_GET['status'])) {
    $status = $_GET['status'];
    // 使用预处理语句增强安全性
    $stmt = mysqli_prepare($con, "SELECT * FROM agents WHERE agentStatus = ?");
    mysqli_stmt_bind_param($stmt, "s", $status);
    mysqli_stmt_execute($stmt);
    $result = mysqli_stmt_get_result($stmt);
} else {
    $result = mysqli_query($con, $sql);
}

// 检查查询是否成功
if (!$result) {
    die('查询失败: ' . mysqli_error($con));
}
?>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>代理商状态筛选</title>
    <style>
        body { font-family: Arial, sans-serif; margin: 20px; }
        .filter-buttons { margin-bottom: 20px; }
        .filter-buttons .btn {
            display: inline-block;
            padding: 8px 15px;
            margin-right: 10px;
            background-color: #007bff;
            color: white;
            text-decoration: none;
            border-radius: 4px;
        }
        .filter-buttons .btn:hover {
            background-color: #0056b3;
        }
        table {
            width: 100%;
            border-collapse: collapse;
            margin-top: 20px;
        }
        th, td {
            border: 1px solid #ddd;
            padding: 8px;
            text-align: left;
        }
        th {
            background-color: #f2f2f2;
        }
    </style>
</head>
<body>
    <h1>代理商列表</h1>

    <div class="filter-buttons">
        <a href="?status=Online" class="btn">在线</a>
        <a href="?status=Offline" class="btn">离线</a>
        <a href="?status=Disconnected" class="btn">已断开</a>
        <a href="?" class="btn">全部</a>
    </div>

    <table id="main_table">
        <thead>
            <tr>
                <th>Id</th>
                <th>Agent Name</th>
                <th>Agent Rank</th>
                <th>Agent Location</th>
                <th>Status</th>
            </tr>
        </thead>
        <tbody>
            <?php
            while ($info = mysqli_fetch_array($result)) {
            ?>
            <tr>
                <td><?php echo htmlspecialchars($info['id']); ?></td>
                <td><?php echo htmlspecialchars($info['agentName']); ?></td>
                <td><?php echo htmlspecialchars($info['agentRank']); ?></td>
                <td><?php echo htmlspecialchars($info['locationNames']); ?></td>
                <td><?php echo htmlspecialchars($info['agentStatus']); ?></td>
            </tr>
            <?php
            }
            ?>
        </tbody>
    </table>

</body>
</html>

<?php
// 关闭数据库连接
mysqli_close($con);
?>

数据库连接文件 (CMS/processing/conn.php) 示例:

<?php
$servername = "localhost";
$username = "your_username";
$password = "your_password";
$dbname = "your_database";

// 创建连接
$con = mysqli_connect($servername, $username, $password, $dbname);

// 检查连接
if (!$con) {
    die("连接失败: " . mysqli_connect_error());
}
// 设置字符集
mysqli_set_charset($con, "utf8");
?>

注意事项

  1. 安全性(SQL注入):在示例代码中,我们已经将直接拼接GET参数的方式替换为预处理语句(Prepared Statements)。这是防止SQL注入最有效的方法。请务必在所有涉及用户输入的数据库操作中采用此方法。
  2. 数据类型匹配:确保GET参数传递的状态值与数据库中agentStatus字段的数据类型和实际存储值完全匹配。例如,如果数据库中存储的是数字(1, 2, 3),则GET参数也应传递数字。
  3. 用户体验:这种服务器端筛选方式会导致页面重新加载。对于数据量较小或对实时性要求更高的场景,可以考虑使用JavaScript(如AJAX)进行客户端筛选或异步加载,以提供更流畅的用户体验。
  4. 错误处理:在实际应用中,应加入更完善的错误处理机制,例如当数据库连接失败或查询出错时,向用户显示友好的错误信息,而不是直接终止脚本。
  5. URL美化:为了更美观的URL和更好的SEO,可以考虑使用Apache的mod_rewrite或Nginx的rewrite规则将?status=Online等参数形式重写为/status/online等路径形式。

总结

通过本教程,您已经学会了如何利用PHP和GET参数实现HTML表格的服务器端数据筛选功能。这种方法简单有效,适用于大多数需要根据特定条件展示数据库数据的场景。在实际开发中,请务必关注安全性,并根据项目需求选择最适合的筛选方案。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1683

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 847人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号