当前位置:首页 > PHP

php实现筛选功能实现

2026-02-15 02:46:35PHP

PHP 筛选功能实现

数据库查询筛选

使用 SQL 的 WHERE 子句结合用户输入构建查询条件。通过预处理语句防止 SQL 注入。

$category = $_GET['category'] ?? '';
$price_min = $_GET['price_min'] ?? 0;
$price_max = $_GET['price_max'] ?? 9999;

$sql = "SELECT * FROM products WHERE 1=1";
$params = [];

if (!empty($category)) {
    $sql .= " AND category = ?";
    $params[] = $category;
}

if ($price_min > 0) {
    $sql .= " AND price >= ?";
    $params[] = $price_min;
}

if ($price_max < 9999) {
    $sql .= " AND price <= ?";
    $params[] = $price_max;
}

$stmt = $pdo->prepare($sql);
$stmt->execute($params);
$results = $stmt->fetchAll(PDO::FETCH_ASSOC);

表单设计

创建 HTML 表单收集筛选条件,使用 GET 方法提交以便保留筛选参数在 URL 中。

<form method="get" action="products.php">
    <select name="category">
        <option value="">所有分类</option>
        <option value="electronics">电子产品</option>
        <option value="clothing">服装</option>
    </select>

    <input type="number" name="price_min" placeholder="最低价格">
    <input type="number" name="price_max" placeholder="最高价格">

    <button type="submit">筛选</button>
</form>

数组数据筛选

对于非数据库数据,可以使用 array_filter 函数实现筛选。

$products = [
    ['name' => 'Laptop', 'category' => 'electronics', 'price' => 1200],
    ['name' => 'T-Shirt', 'category' => 'clothing', 'price' => 20]
];

$filtered = array_filter($products, function($item) {
    $match = true;
    if (isset($_GET['category']) && $_GET['category'] !== '' 
        && $item['category'] !== $_GET['category']) {
        $match = false;
    }
    if (isset($_GET['price_min']) && $item['price'] < $_GET['price_min']) {
        $match = false;
    }
    return $match;
});

分页处理

结合筛选实现分页功能,计算总记录数和分页参数。

$page = $_GET['page'] ?? 1;
$per_page = 10;
$offset = ($page - 1) * $per_page;

$count_sql = "SELECT COUNT(*) FROM products WHERE 1=1" . $where_clause;
$total = $pdo->query($count_sql)->fetchColumn();
$total_pages = ceil($total / $per_page);

$sql .= " LIMIT $offset, $per_page";

结果展示

在页面中显示筛选结果和分页导航。

php实现筛选功能实现

foreach ($results as $product) {
    echo "<div>{$product['name']} - {$product['price']}</div>";
}

for ($i = 1; $i <= $total_pages; $i++) {
    echo "<a href='?page=$i&category={$_GET['category']}'>$i</a> ";
}

通过以上方法可以实现完整的筛选功能,包括数据库查询、表单处理、分页和结果显示。确保对用户输入进行验证和过滤以保证安全性。

标签: 功能php
分享给朋友:

相关文章

js实现复制功能

js实现复制功能

使用 document.execCommand 方法 这种方法适用于较旧的浏览器,但在现代浏览器中可能被逐步淘汰。通过创建一个临时的 textarea 元素,将文本内容放入其中,然后执行复制命令。…

php长连接实现

php长连接实现

PHP 长连接实现方法 长连接(Keep-Alive)允许客户端与服务器在一次TCP连接中发送和接收多个HTTP请求/响应,减少重复建立连接的开销。以下是PHP中实现长连接的几种方式: 配置HTTP…

php 实现秒杀

php 实现秒杀

PHP 实现秒杀的关键技术 秒杀系统需要解决高并发、超卖、性能瓶颈等问题。以下是实现秒杀的核心方案: 使用 Redis 预减库存 将商品库存提前加载到 Redis 中,通过原子操作保证库存准确性:…

php实现统计

php实现统计

PHP 实现统计功能 在 PHP 中实现统计功能通常涉及数据的收集、处理和展示。以下是一些常见的统计实现方法: 数据库数据统计 通过 SQL 查询可以直接从数据库中获取统计结果: $conn =…

php实现的进度条

php实现的进度条

PHP 实现的进度条方法 在 PHP 中实现进度条通常可以通过命令行脚本(CLI)或 Web 页面两种方式完成。以下是几种常见的实现方法: 命令行进度条 使用 PHP CLI 实现进度条,可以通过不…

php session实现购物车

php session实现购物车

PHP Session 实现购物车 初始化 Session 确保在使用 Session 前调用 session_start() 函数。通常放在 PHP 文件的最顶部。 <?php sessio…