js实现表格筛选功能


Posted in Javascript onJanuary 18, 2017

js实现表格筛选功能

本应用就两个主要实现:

1.表格的id 和 class之间的命名关系

请看图: 将组名和个人信息联表格联系起来,这样会很好的操作表格

js实现表格筛选功能

HTML代码:

<tr class="parent" id="row_01"><td colspan="3">前台设计组</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 colspan="3">前台开发组</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>

2.就是筛选功能的使用:使用filter联合contains将输入框的字加入contains进行筛选

javascript代码:

//设置列表查询
 $("#filterName").keyup(function () {
  $("table tbody tr").stop().hide() //将tbody中的tr都隐藏
    .filter(":contains('"+($(this).val())+"')").show(); //,将符合条件的筛选出来
  
  });

下面是完整代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>表格应用</title>
 <style>
  *{
   margin: 0;
   padding: 0;
  }
  .box{
   border: 1px solid #000;
   margin:50px auto;
   width: 340px;
   padding: 10px 10px;
  }
  .box table{
   margin: auto;
  }
  .box .box-top{
   width: 303px;
   margin: 5px auto;
  }
  .box table tr td,th{
   padding: 5px 30px;
   text-align: center;
  }
  .box table .parent{
   background: lightgray;
  }
  .selected{
   background: gray !important;
  }
  .selectHeight{
   background: darkseagreen !important;
  }
 </style>
</head>
<body>
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
 $(function () {
  //默认让王五选中
  $("tr:contains('王五')").addClass("selectHeight")
  //点击让其展示出列表 默认让其都隐藏
  $(".box tr.parent").click(function () {
   $(this)
    .toggleClass("selected")
    .siblings(".child_"+this.id).stop().toggle();
  }).click();//此行代码表示要立即执行
  //设置列表查询
  $("#filterName").keyup(function () {
   $("table tbody tr").stop().hide() //将tbody中的tr都隐藏
    .filter(":contains('"+($(this).val())+"')").show(); //,将符合条件的筛选出来
  });
 });
</script>
<div class="box">
 <div class="box-top">
  <span>筛选:</span><input type="text" id="filterName">
 </div>
 <table>
  <thead>
   <tr>
    <th>姓名</th>
    <th>性别</th>
    <th>暂住地</th>
   </tr>
  </thead>
  <tbody>
   <tr class="parent" id="row_01"><td colspan="3">前台设计组</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 colspan="3">前台开发组</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 colspan="3">后台设计组</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>
</div>
</body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
excel操作之Add Data to a Spreadsheet Cell
Jun 12 Javascript
jquery win 7透明弹出层效果的简单代码
Aug 06 Javascript
JS加jquery简单实现标签元素的显示或隐藏
Sep 23 Javascript
AngularJS基础 ng-srcset 指令简单示例
Aug 03 Javascript
jquery实现拖动效果
Aug 10 Javascript
JS用斜率判断鼠标进入DIV四个方向的方法
Nov 07 Javascript
浅析javaScript中的浅拷贝和深拷贝
Feb 15 Javascript
jQuery Autocomplete简介_动力节点Java学院整理
Jul 17 jQuery
JavaScript requestAnimationFrame动画详解
Sep 14 Javascript
JS简单实现动态添加HTML标记的方法示例
Apr 08 Javascript
JS中验证整数和小数的正则表达式
Oct 08 Javascript
vue实现拖拽交换位置
Apr 07 Vue.js
js放大镜放大购物图片效果
Jan 18 #Javascript
详解vue 中使用 AJAX获取数据的方法
Jan 18 #Javascript
easyui 中的datagrid跨页勾选问题的实现方法
Jan 18 #Javascript
JavaScript日期对象(Date)基本用法示例
Jan 18 #Javascript
jQuery中的一些小技巧
Jan 18 #Javascript
AngularJS Select(选择框)使用详解
Jan 18 #Javascript
基于JavaScript实现屏幕滚动效果
Jan 18 #Javascript
You might like
探讨如何在PHP开启gzip页面压缩实例
2013/06/09 PHP
PHP批量查询WordPress留言者E-mail地址实现方法
2015/02/15 PHP
php中目录操作opendir()、readdir()及scandir()用法示例
2019/06/08 PHP
Js 时间间隔计算的函数(间隔天数)
2011/11/15 Javascript
javascript中直接写php代码的方法
2013/07/31 Javascript
jQuery ajax dataType值为text json探索分享
2013/09/23 Javascript
一款基jquery超炫的动画导航菜单可响应单击事件
2014/11/02 Javascript
jQuery实现的调整表格行tr上下顺序
2016/01/10 Javascript
javascript使用Promise对象实现异步编程
2016/03/01 Javascript
js HTML5上传示例代码完整版
2016/10/10 Javascript
jQuery实现倒计时重新发送短信验证码功能示例
2017/01/12 Javascript
Bootstrap栅格系统使用方法及页面调整变形的解决方法
2017/03/10 Javascript
JS实现禁止用户使用Ctrl+鼠标滚轮缩放网页的方法
2017/04/28 Javascript
用js将long型数据转换成date型或datetime型的实例
2017/07/03 Javascript
Angular2里获取(input file)上传文件的内容的方法
2017/09/05 Javascript
详解Vue源码学习之双向绑定
2019/04/10 Javascript
Vue使用axios引起的后台session不同操作
2020/08/14 Javascript
python条件和循环的使用方法
2013/11/01 Python
Python函数式编程指南(三):迭代器详解
2015/06/24 Python
SVM基本概念及Python实现代码
2017/12/27 Python
使用pygame模块编写贪吃蛇的实例讲解
2018/02/05 Python
Django权限机制实现代码详解
2018/02/05 Python
python使用zip将list转为json的方法
2018/12/31 Python
利用python求积分的实例
2019/07/03 Python
美国在线珠宝商店:SZUL
2017/02/11 全球购物
李宁官方网店:中国运动品牌
2017/11/02 全球购物
豪华复古化妆:Besame Cosmetics
2019/09/06 全球购物
构造器Constructor是否可被override?
2013/08/06 面试题
学校介绍信范文
2014/01/14 职场文书
文化与传播毕业生求职信
2014/03/09 职场文书
选秀节目策划方案
2014/06/06 职场文书
2015年餐厅服务员工作总结
2015/04/23 职场文书
婚礼上证婚人致辞
2015/07/28 职场文书
一文搞懂如何实现Go 超时控制
2021/03/30 Python
SQL优化老出错,那是你没弄明白MySQL解释计划用法
2021/11/27 MySQL
python playwright之元素定位示例详解
2022/07/23 Python