0

0

jQuery表格日期筛选:优化input type="date"的搜索体验

花韻仙語

花韻仙語

发布时间:2025-08-16 14:52:42

|

1053人浏览过

|

来源于php中文网

原创

jQuery表格日期筛选:优化input type=

本教程详细介绍了如何利用jQuery实现HTML表格数据的日期筛选功能。针对input type="date"类型输入框的特性,文章重点阐述了为何应使用change事件而非keyup事件来触发筛选逻辑,并提供了完整的HTML、CSS和JavaScript代码示例,帮助开发者构建响应式、用户友好的日期搜索界面。

引言

在web应用开发中,表格数据展示和筛选是常见需求。当表格中包含日期信息时,用户往往希望能够通过日期输入框进行快速筛选。jquery提供了一种简洁高效的方式来实现这一功能。然而,对于html5的<input type="date">元素,其行为与普通文本输入框有所不同,这要求我们在事件监听上做出相应的调整,以确保筛选逻辑能够正确触发。

理解问题:input type="date"与事件监听

传统的文本输入框(<input type="text">)通常通过监听keyup事件来实时捕获用户的输入,并立即执行搜索或筛选操作。例如:

$(document).ready(function(){
  $("#myInput").on("keyup", function() {
    var value = $(this).val().toLowerCase();
    $("#myTable tr").filter(function() {
      $(this).toggle($(this).text().toLowerCase().indexOf(value) > -1)
    });
  });
});

这段代码对于文本输入框非常有效,它会实时根据用户键入的字符筛选表格行。然而,当我们将输入框类型改为<input type="date">时,问题就出现了。<input type="date">元素在用户通过日历选择器选择日期时,并不会触发keyup事件,因为用户并没有“键入”字符。因此,如果继续使用keyup事件,当用户通过日历选择日期后,筛选功能将不会被激活,导致用户体验不佳。

解决方案:利用change事件进行日期筛选

解决input type="date"筛选问题的关键在于选择正确的事件监听器。change事件会在元素的值发生改变并且失去焦点时触发。对于<input type="date">,这意味着当用户通过日历选择了一个日期并关闭日历选择器,或者手动输入日期并离开输入框时,change事件就会被触发。这正是我们希望筛选逻辑执行的时机。

将事件监听从keyup改为change,即可完美解决此问题:

$(document).ready(function(){
  $("#myInput").on("change", function() { // 将 keyup 改为 change
    let value = $(this).val().toLowerCase();
    $("#myTable tr").filter(function() {
      // 假设表格中的日期格式与 input type="date" 的输出格式一致 (YYYY-MM-DD)
      $(this).toggle($(this).text().toLowerCase().indexOf(value) > -1);
    });
  });
});

完整实现示例

以下是一个完整的HTML页面示例,展示了如何使用jQuery和change事件实现表格日期筛选功能:

Face++旷视
Face++旷视

Face⁺⁺ AI开放平台

下载
<!DOCTYPE html>
<html>
<head>
<title>jQuery表格日期筛选</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<style>
  table {
    font-family: arial, sans-serif;
    border-collapse: collapse;
    width: 100%;
  }

  td, th {
    border: 1px solid #dddddd;
    text-align: left;
    padding: 8px;
  }

  tr:nth-child(even) {
    background-color: #dddddd;
  }

  input[type="date"] {
    padding: 8px;
    margin-bottom: 15px;
    border: 1px solid #ccc;
    border-radius: 4px;
  }
</style>
</head>
<body>

<input id="myInput" type="date" placeholder="搜索日期..">
<br><br>

<table>
  <thead>
  <tr>
    <th>姓名</th>
    <th>姓氏</th>
    <th>日期</th>
  </tr>
  </thead>
  <tbody id="myTable">
  <tr>
    <td>张</td>
    <td>三</td>
    <td>2022-06-03</td>
  </tr>
  <tr>
    <td>李</td>
    <td>四</td>
    <td>2022-06-04</td>
  </tr>
  <tr>
    <td>王</td>
    <td>五</td>
    <td>2022-06-05</td>
  </tr>
  <tr>
    <td>赵</td>
    <td>六</td>
    <td>2022-06-06</td>
  </tr>
  <tr>
    <td>孙</td>
    <td>七</td>
    <td>2022-07-01</td>
  </tr>
  </tbody>
</table>

<script>
$(document).ready(function(){
  $("#myInput").on("change", function() {
    // 获取输入框的值,并转换为小写以进行不区分大小写的匹配
    let searchValue = $(this).val().toLowerCase();

    // 遍历表格中的每一行
    $("#myTable tr").filter(function() {
      // 获取当前行的所有文本内容,并转换为小写
      let rowText = $(this).text().toLowerCase();

      // 判断行文本是否包含搜索值
      // 如果包含,则显示该行;否则隐藏
      $(this).toggle(rowText.indexOf(searchValue) > -1);
    });
  });
});
</script>

</body>
</html>

代码解析

  1. HTML结构:

    • input id="myInput" type="date":这是核心的日期输入框,用户将在此选择或输入日期。
    • table:包含<thead>(表头)和<tbodyyoujiankuohaophpcn(表体)。
    • tbody id="myTable":表格的主体部分,筛选操作将针对其内部的<tr>元素进行。
  2. CSS样式:

    • 提供了基本的表格和输入框样式,使其更具可读性。
  3. JavaScript逻辑:

    • $(document).ready(function(){ ... });:确保DOM完全加载后再执行脚本。
    • $("#myInput").on("change", function() { ... });:这是关键部分。它监听ID为myInput的日期输入框的change事件。当用户选择或输入日期并离开输入框时,此函数将被调用。
    • let searchValue = $(this).val().toLowerCase();:获取当前日期输入框的值。input type="date"的value属性通常以YYYY-MM-DD格式返回日期字符串。toLowerCase()用于确保后续匹配的不区分大小写。
    • $("#myTable tr").filter(function() { ... });:选中myTable中所有的表格行(<tr>),并对每一行执行一个过滤函数。
    • let rowText = $(this).text().toLowerCase();:在过滤函数内部,$(this)代表当前的<tr>元素。.text()方法获取该行中所有单元格的文本内容,并转换为小写。
    • $(this).toggle(rowText.indexOf(searchValue) > -1);:这是筛选的核心逻辑。
      • rowText.indexOf(searchValue) > -1:检查当前行的文本内容(rowText)是否包含搜索值(searchValue)。如果包含,indexOf将返回搜索值首次出现的索引(大于-1);如果不包含,则返回-1。
      • $(this).toggle(...):jQuery的toggle()方法根据传入的布尔值决定元素的显示或隐藏。如果布尔值为true(即包含搜索值),则显示该行;如果为false(不包含搜索值),则隐藏该行。

注意事项

  • 日期格式一致性: 本教程的筛选逻辑依赖于input type="date"输出的YYYY-MM-DD格式与表格中日期文本格式的精确匹配。如果表格中的日期格式是MM/DD/YYYY或其他形式,indexOf将无法正确匹配。在这种情况下,你需要对表格中的日期文本或搜索值进行格式转换,使其保持一致。
  • 日期范围筛选: indexOf方法适用于精确匹配日期字符串。如果需要实现日期范围筛选(例如,查找某个日期区间内的记录),则需要更复杂的逻辑,包括将日期字符串解析为日期对象,然后进行日期比较。
  • 性能优化: 对于包含大量行(例如数千行)的表格,每次change事件都遍历所有行可能会有性能开销。可以考虑引入去抖动(debounce)或节流(throttle)技术,限制筛选操作的频率,或使用更高效的数据结构和算法。
  • 用户体验: 可以在输入框旁边添加一个清除按钮,方便用户快速清除筛选条件。

总结

通过将事件监听器从keyup切换到change,我们成功解决了input type="date"元素在日历选择后不触发筛选的问题。这个简单的改动使得表格日期筛选功能更加健壮和用户友好。掌握这种细微但关键的事件处理差异,是构建高质量前端应用的重要一步。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

550

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

474

2024.03.06

html5从入门到精通汇总
html5从入门到精通汇总

想系统掌握HTML5开发?本合集精选全网优质学习资源,涵盖免费教程、实战项目、视频课程与权威电子书,从基础语法到高级特性(Canvas、本地存储、响应式布局等)一应俱全,适合零基础小白到进阶开发者,助你高效入门并精通HTML5前端开发。

301

2025.12.30

html5新老标签汇总
html5新老标签汇总

HTML5在2026年持续优化网页语义化与交互体验,不仅引入了如<header>、<nav>、<article>、<section>、<aside>、<footer>等结构化标签,还新增了<video>、<audio>、<canvas>、<figure>、<time>、<mark>等增强多媒体与

230

2025.12.30

html5空格代码怎么写
html5空格代码怎么写

在HTML5中,空格不能直接通过键盘空格键实现,需使用特定代码。本合集详解常用空格写法:&nbsp;(不间断空格)、&ensp;(半个中文空格)、&emsp;(一个中文空格)及CSS的white-space属性等方法,帮助开发者精准控制页面排版,避免因空格失效导致布局错乱,适用于新手入门与实战参考。

108

2025.12.30

html5怎么做网站教程
html5怎么做网站教程

想从零开始学做网站?这份《HTML5怎么做网站教程》合集专为新手打造!涵盖HTML5基础语法、页面结构搭建、表单与多媒体嵌入、响应式布局及与CSS3/JavaScript协同开发等核心内容。无需编程基础,手把手教你用纯HTML5创建美观、兼容、移动端友好的现代网页。附实战案例+代码模板,快速上手,轻松迈出Web开发第一步!

165

2025.12.31

HTML5建模教程
HTML5建模教程

想快速掌握HTML5模板搭建?本合集汇集实用HTML5建模教程,从零基础入门到实战开发全覆盖!内容涵盖响应式布局、语义化标签、Canvas绘图、表单验证及移动端适配等核心技能,提供可直接复用的模板结构与代码示例。无需复杂配置,助你高效构建现代网页,轻松上手前端开发!

53

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

73

2025.12.31

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

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

69

2026.03.13

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.6万人学习

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

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