当前位置:首页 > 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";

结果展示

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

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实现筛选功能实现

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

相关文章

vue修改功能实现

vue修改功能实现

Vue 修改功能的实现方法 在 Vue 中实现修改功能通常涉及表单绑定、数据更新和事件处理。以下是几种常见的实现方式: 数据双向绑定 使用 v-model 指令实现表单元素与 Vue 实例数据的双向…

vue实现账号注册功能

vue实现账号注册功能

实现账号注册功能 在Vue中实现账号注册功能通常需要结合前端表单和后端API交互。以下是一个完整的实现方案: 创建注册表单组件 新建一个Register.vue组件,包含基本的注册表单字段:…

vue的艾特功能实现

vue的艾特功能实现

Vue 中的 @ 功能实现 Vue 中的 @ 符号是 v-on 指令的简写,用于绑定事件监听器。以下是具体实现方式: 基本语法 <button @click="handleClick">…

php实现搜索功能

php实现搜索功能

实现基本的搜索功能 在PHP中实现搜索功能通常涉及数据库查询。以下是一个简单的实现方式,假设使用MySQL数据库: <?php // 连接数据库 $conn = new mysqli('loc…

php实现增删改查

php实现增删改查

以下是在PHP中实现增删改查(CRUD)操作的详细方法,以MySQL数据库为例: 数据库连接配置 创建config.php文件存储数据库连接信息: <?php $host = 'loca…

php实现队列

php实现队列

PHP实现队列的方法 队列是一种先进先出(FIFO)的数据结构,PHP可以通过多种方式实现队列功能。 使用数组模拟队列 PHP数组可以模拟队列的基本操作,通过array_push和array_sh…