基于jquery实现表格内容筛选功能实例解析

前端技术 2023/09/05 JavaScript

当表格内的数据较多时,我们无法一页一页的查找,这时可以通过一个搜索框来实现搜索。

对于这个搜素框,我们为了更好的体验可以利用keyup事件实现在用户输入的时候就开始筛选,而不是填完以后点击搜索按钮再执行。
效果图:

实现代码:

<html>
<head>
 <meta charset=\"utf-8\" />
 <script src=\"jquery-1.3.2.min.js\"></script>
 <link href=\"css/style.css\" rel=\"stylesheet\" type=\"text/css\" />
 <script>
  $(function () {
   $(\"tr.parent\").click(function () {
    $(this)
    .siblings(\'.child_\'+this.id).toggle();
    
   });
   $(\"tr.parent\").addClass(\"selected\");
   $(\"#searchbox\").keyup(function () {
    $(\"table tbody tr\").hide()
    .filter(\":contains(\'\"+($(this).val())+\"\')\").show();//filter和contains共同来实现了这个功能。
   }).keyup();
  });
 </script>
 <title></title>
</head>
<body>
 <label>筛选</label>
 <input type=\"text\" id=\"searchbox\"/>
 <table>
  <thead>
   <tr><td>姓名</td><td>性别</td><td>暂住地</td></tr>
  </thead>
  <tbody>
   <tr class=\"parent\" id=\"row_01\"><td>前台设计组</td></tr>
   <tr class=\"child_row_01\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_01\"><td>李山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_01\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_01\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"parent\" id=\"row_02\"><td>前台设计组</td></tr>
   <tr class=\"child_row_02\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_02\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_02\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_02\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"parent\" id=\"row_03\"><td>前台设计组</td></tr>
   <tr class=\"child_row_03\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_03\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_03\"><td>张山</td><td>男</td><td>湖北</td></tr>
   <tr class=\"child_row_03\"><td>张山</td><td>男</td><td>湖北</td></tr>
  </tbody>
 </table>
</body>
</html>

以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。

本文地址:https://www.stayed.cn/item/12318

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。