0

0

HTML表格动态过滤:使用jQuery实现高效数据检索

碧海醫心

碧海醫心

发布时间:2025-10-11 12:20:31

|

1255人浏览过

|

来源于php中文网

原创

HTML表格动态过滤:使用jQuery实现高效数据检索

本教程详细讲解如何利用jqueryhtml表格添加实时动态过滤功能。文章首先指出常见的html结构错误,如id放置不当,并纠正jquery选择器,确保过滤操作作用于整个表格行而非单个单元格。通过完整的代码示例,读者将学习如何构建一个响应式且用户友好的表格搜索功能,提升数据交互体验。

1. HTML表格结构与过滤基础

在为HTML表格添加动态过滤功能之前,确保表格的HTML结构是标准且语义化的至关重要。一个标准的HTML表格应包含 <table>、<thead>、<tbody> 等元素,并为整个表格(<table>标签)设置一个唯一的ID,以便jQuery能够准确地定位和操作。

正确的HTML表格结构示例:

<table id="myTable">
    <thead>
        <tr>
            <th>列标题1</th>
            <th>列标题2</th>
            <th>列标题3</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>数据1-1</td>
            <td>数据1-2</td>
            <td>数据1-3</td>
        </tr>
        <tr>
            <td>数据2-1</td>
            <td>数据2-2</td>
            <td>数据2-3</td>
        </tr>
        <!-- 更多数据行 -->
    </tbody>
</table>

常见错误及纠正: 在实际开发中,有时会将表格的ID错误地放置在 <tbody> 标签上,甚至将 <table> 嵌套在 <tbody> 内部。这会导致HTML结构无效,并使jQuery选择器无法正确工作。例如,如果 id="myTable" 错误地赋给了 <tbody>,那么 $("#myTable td") 或 $("#myTable tr") 将无法按预期选择到整个表格的单元格或行,因为 myTable 仅代表了表格的一部分。正确的做法是将 id="myTable" 赋予最外层的 <table> 标签。

2. jQuery动态过滤核心逻辑

实现表格动态过滤主要依赖于监听用户在搜索框中的输入事件,并根据输入内容实时显示或隐藏表格行。

核心JavaScript代码解析:

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载

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

$(document).ready(function() {
    $("#myInput").on("keyup", function() {
        var value = $(this).val().toLowerCase(); // 获取搜索框内容并转换为小写,实现不区分大小写搜索
        var found = false; // 标记是否找到匹配项

        // 选择器:$("#myTable tbody tr") 确保我们只操作数据行,避免影响表头
        // .not("#noResultsRow") 排除掉可能存在的“无结果”提示行
        $("#myTable tbody tr").not("#noResultsRow").filter(function() {
            // 获取当前行的所有文本内容,转换为小写
            // 判断是否包含搜索值
            var rowMatches = $(this).text().toLowerCase().indexOf(value) > -1;

            // 根据匹配结果显示或隐藏当前行
            $(this).toggle(rowMatches); 

            if (rowMatches) {
                found = true; // 如果有行匹配,则设置found为true
            }
            return rowMatches; // filter函数需要一个返回值,虽然toggle已处理显示/隐藏
        });

        // 处理“无匹配结果”提示
        if (!found && value.length > 0) { // 只有在没有找到匹配项且搜索框不为空时显示
            $("#noResultsRow").show();
        } else {
            $("#noResultsRow").hide();
        }

        // 当搜索框内容被清空时,显示所有行
        if (value === "") {
            $("#myTable tbody tr").show();
            $("#noResultsRow").hide();
        }
    });
});

关键点说明:

  • $(document).ready(function() { ... });: 确保在DOM加载完成后执行JavaScript代码。
  • $("#myInput").on("keyup", function() { ... });: 监听ID为 myInput 的输入框的 keyup 事件。每当用户松开键盘按键时,就会触发此函数。
  • var value = $(this).val().toLowerCase();: 获取当前输入框的值,并使用 toLowerCase() 方法将其转换为小写。这使得搜索功能不区分大小写,提升用户体验。
  • $("#myTable tbody tr").not("#noResultsRow").filter(function() { ... });:
    • $("#myTable tbody tr"): 这是关键的选择器。它精确地选择了ID为 myTable 的表格内部 <tbody> 中的所有 <tr>(表格数据行)。这样可以确保过滤操作只作用于数据行,而不会影响到 <thead> 中的表头。
    • .not("#noResultsRow"): 排除掉一个特殊的行,通常用于显示“未找到匹配结果”的提示,防止它被错误地隐藏或参与过滤。
    • .filter(function() { ... }): 遍历所有选中的 <tr> 元素。对于每个 <tr>,执行回调函数
  • $(this).text().toLowerCase().indexOf(value) > -1:
    • $(this).text(): 获取当前 <tr> 元素(即当前行)内部所有文本内容的组合。
    • .toLowerCase(): 将获取到的文本转换为小写。
    • .indexOf(value) > -1: 检查转换后的文本是否包含搜索值。如果包含,indexOf() 返回该子字符串的起始索引(大于-1),否则返回-1。
  • $(this).toggle(rowMatches);: 这是jQuery提供的一个便捷方法。如果 rowMatches 为 true,则显示当前行;如果为 false,则隐藏当前行。
  • “无匹配结果”提示处理: 通过一个 found 变量和额外的 $("#noResultsRow") 行,可以在没有搜索到任何结果时向用户提供友好的提示。

3. 完整的示例代码

以下是一个包含HTML、CSS和JavaScript的完整示例,展示了如何实现表格的动态过滤功能。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>HTML表格动态过滤示例</title>
    <!-- 引入jQuery库 -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <style>
        body { font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; margin: 20px; background-color: #f4f7f6; color: #333; }
        .container { max-width: 960px; margin: 30px auto; padding: 25px; background-color: #fff; border-radius: 8px; box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
        h2 { color: #0056b3; text-align: center; margin-bottom: 30px; }
        label { display: block; margin-bottom: 8px; font-weight: bold; color: #555; }
        #myInput {
            width: 100%;
            padding: 12px 15px;
            margin-bottom: 20px;
            box-sizing: border-box;
            border: 1px solid #ccc;
            border-radius: 5px;
            font-size: 16px;
            transition: border-color 0.3s ease-in-out;
        }
        #myInput:focus {
            border-color: #007bff;
            outline: none;
        }
        table {
            width: 100%;
            border-collapse: collapse;
            margin-top: 20px;
            background-color: #fff;
        }
        th, td {
            border: 1px solid #e0e0e0;
            padding: 12px 15px;
            text-align: left;
            font-size: 14px;
        }
        th {
            background-color: #e9ecef;
            color: #495057;
            font-weight: 600;
            white-space: nowrap; /* Prevent header text from wrapping */
        }
        tbody tr:nth-child(even) {
            background-color: #f8f9fa;
        }
        tbody tr:hover {
            background-color: #e2f0ff;
            cursor: pointer;
        }
        tr.no-results td {
            text-align: center;
            font-style: italic;
            color: #888;
            padding: 20px;
            background-color: #fdfefe;
        }
    </style>
</head>
<body>
    <div class="container">
        <h2>测试结果动态过滤</h2>

        <label for="myInput">搜索测试用例或结果:</label>
        <input id="myInput" type="text" placeholder="输入关键词进行搜索...">

        <table id="myTable">
            <thead>
                <tr>
                    <th style="width: 5%;">序号</th>
                    <th style="width: 25%;">测试用例</th>
                    <th style="width: 10%;">结果</th>
                    <th style="width: 20%;">章节</th>
                    <th style="width: 30%;">原因</th>
                    <th style="width: 10%;">分析</th>
                </tr>
            </thead>
            <tbody>
                <tr><td>0</td><td>CallsiteMemLeakReportInitial</td><td>FAILED</td><td>section test_case</td><td>Mem leak found before the run</td><td>Script issue</td></tr>
                <tr><td>1</td><td>FinalMemLeakReport</td><td>FAILED</td><td>section check_final_mem_leaks</td><td>Memory Leaks Found</td><td>Script issue</td></tr>
                <tr><td>2</td><td>CallsiteMemLeakReportFinal</td><td>FAILED</td><td>section test_case</td><td>Mem leak found before the run</td><td>Script issue</td></tr>
                <tr><td>3</td><td>InitialMemLeakReport</td><td>PASSED</td><td></td><td></td><td></td></tr>
                <tr><td>4</td><td>TriggerInterfaceFlaps</td><td>PASSED</td><td></td><td></td><td></td>

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
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

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

312

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

129

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

51

2026.01.13

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

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

49

2026.03.13

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.3万人学习

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

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