0

0

实现搜索结果按字母顺序排序的 PHP 教程

霞舞

霞舞

发布时间:2025-10-05 15:55:06

|

475人浏览过

|

来源于php中文网

原创

实现搜索结果按字母顺序排序的 php 教程

本文档介绍如何使用 PHP 和 AJAX 对通过 POST 方法获取的搜索结果进行 A-Z 排序。我们将创建一个表单,保存 POST 数据,并使用 PHP 函数对医生列表进行排序,最终通过 AJAX 异步更新页面显示排序后的结果,提升用户体验。

1. 修改 search.php 添加排序表单

首先,在 search.php 页面中添加一个表单,用于触发排序操作。该表单包含一个隐藏域,用于保存原始的 POST 数据,以及一个排序按钮。

<form id="sortForm" method="post">
    <input type="hidden" name="original_post_data" value="<?php echo htmlspecialchars(json_encode($_POST)); ?>">
    <button type="button" id="sortButton" class="btn btn-primary">按 A-Z 排序</button>
</form>

说明:

  • original_post_data 隐藏域:将原始的 $_POST 数据进行 JSON 编码后存储,以便在排序时能够重新使用这些数据。使用 htmlspecialchars 函数进行转义,防止 XSS 攻击。
  • sortButton 按钮:触发 AJAX 请求,执行排序操作。

2. 添加 JavaScript 代码处理排序请求

接下来,使用 JavaScript 代码监听排序按钮的点击事件,并使用 AJAX 发送请求到服务器。

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

CreateWise AI
CreateWise AI

为播客创作者设计的AI创作工具,AI自动去口癖、提交亮点和生成Show notes、标题等

下载
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script>
$(document).ready(function(){
    $("#sortButton").click(function(){
        var originalPostData = $("input[name='original_post_data']").val();

        $.ajax({
            url: "sort_doctors.php", // 排序处理脚本
            type: "POST",
            data: {
                sort: 'az', // 排序方式
                original_post_data: originalPostData
            },
            success: function(data){
                // 将排序后的结果更新到页面
                $(".container").html(data); // 假设医生列表在 class="container" 的元素中
            },
            error: function(xhr, status, error) {
                console.error("AJAX 请求失败: " + status + " - " + error);
            }
        });
    });
});
</script>

说明:

  • 引入 jQuery 库,简化 AJAX 操作。
  • 监听 sortButton 的点击事件。
  • 获取 original_post_data 隐藏域的值。
  • 使用 $.ajax 发送 POST 请求到 sort_doctors.php。
  • 传递 sort 参数指定排序方式('az' 表示 A-Z 排序)。
  • 在 success 回调函数中,将服务器返回的排序后的结果更新到页面上。
  • 在 error 回调函数中,处理 AJAX 请求失败的情况。

3. 创建 sort_doctors.php 处理排序逻辑

创建 sort_doctors.php 文件,用于处理排序逻辑。

<?php
include 'models/doctors.class.php';

$search = new doctors();

if(isset($_POST['sort']) && $_POST['sort'] == 'az' && isset($_POST['original_post_data'])) {
    $originalPostData = json_decode($_POST['original_post_data'], true);

    // 模拟 POST 请求
    $_POST = $originalPostData;

    $s = $search->filterDoctors($_POST);

    // 对结果集按照 full_name 字段进行 A-Z 排序
    usort($s, function($a, $b) {
        return strcmp($a['full_name'], $b['full_name']);
    });

    // 输出排序后的结果
    foreach($s as $row1){
?>
    <a href="therapist.php?id=<?php echo $row1['User_ID']; ?>" class="text-decoration-none">
        <div class="therapistCardOne mx-2 popins-font my-2">
            <div class="row py-2">
                <div class="col-3 g-0">
                    <div class="imgW text-center g-0 ps-2">
                        <img src="assets/images/006.png" class="img-fluid ms-2" alt="" width="70px"
                            height="80px">
                    </div>
                </div>
                <div class="col-8 g-0 ps-2">
                    <span class="span1"><?php echo $row1['full_name'];?></span>
                    <span class="ps-2">
                        <i class="bi bi-star-fill icon-ccc"></i>
                        <i class="bi bi-star-fill icon-ccc"></i>
                        <i class="bi bi-star-fill icon-ccc"></i>
                        <i class="bi bi-star-fill icon-ccc"></i>
                        <i class="bi bi-star icon-ccc"></i></span><br>
                    <span class="span2">Location :
                        <?php echo $row1['location'];?>
                    </span> <br>
                    <span class="span3"><i class="bi bi-clock icon-cc"></i> 12:00pm - 16:00pm</span> <span
                        class="span4 ps-2"><i class="bi bi-geo-alt icon-cc"></i> Zurich New Clinic</span>
                </div>
                <div class="col-1 g-0 pe-2">
                    <i class="bi bi-three-dots-vertical"></i>
                </div>
            </div>
        </div>
    </a>
<?php
    }
} else {
    echo "Invalid request.";
}
?>

说明:

  • 包含 doctors.class.php 文件。
  • 检查 sort 参数是否为 'az',以及 original_post_data 是否存在。
  • 使用 json_decode 函数将 original_post_data 解码为 PHP 数组。
  • 将解码后的数据赋值给 $_POST,模拟原始的 POST 请求。
  • 调用 $search->filterDoctors($_POST) 函数获取医生列表。
  • 使用 usort 函数对医生列表按照 full_name 字段进行 A-Z 排序。usort函数接受一个数组和一个比较函数作为参数。比较函数接收两个数组元素作为参数,并返回一个整数,表示它们的相对顺序。strcmp函数用于比较字符串。
  • 循环遍历排序后的医生列表,并输出 HTML 代码。
  • 如果请求无效,则输出错误信息。

4. 注意事项

  • 确保 doctors.class.php 文件中的 filterDoctors 函数能够正确处理 POST 数据,并返回医生列表。
  • 根据实际情况修改 HTML 代码,使其与你的页面结构相匹配。
  • 可以添加错误处理机制,例如,当 AJAX 请求失败时,显示错误信息。
  • 可以添加加载动画,提升用户体验。
  • 如果需要支持其他排序方式,例如 Z-A 排序,可以添加相应的逻辑。
  • original_post_data 隐藏域存储了敏感数据,需要进行适当的保护,例如,使用 HTTPS 协议传输数据。

总结

通过以上步骤,我们可以实现搜索结果按字母顺序排序的功能。该方案使用 AJAX 异步更新页面,避免了页面刷新,提升了用户体验。同时,该方案也具有一定的灵活性,可以方便地扩展到其他排序方式。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

406

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

515

2023.12.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共137课时 | 13.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

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

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