原生JS 实现的input输入时表格过滤操作示例


Posted in Javascript onAugust 03, 2019

本文实例讲述了原生JS 实现的input输入时表格过滤操作。分享给大家供大家参考,具体如下:

需求:对input框进行键盘输入后根据输入的内容去匹配表格中指定的数据项,若存在相匹配的则只显示匹配的数据项;

细节处理:监听键盘输入后给一定的缓冲时间避免发生频繁的请求;

解决思路:给个定时器,当键盘开始输入时启动定时器,倘若在指定的时间内都不在进行输入操作,则执行匹配操作,否则取消操作,同时限定输入的字符串大于等于2位数字时再进行匹配操作,使过滤效果更精准一些。

<!--JS -->

var timer = null; //定义定时器
function filterTable(el){
  clearTimeout(timer);
  var oTable = document.getElementById("oTable");
  //获取需要匹配的元素集合
  var firstTdArr = oTable.getElementsByClassName("firstTd");
  if(el.value.length>1){ //限定匹配的字符至少为两位数
    var filterVal = el.value.toUpperCase();
    timer = setTimeout(function(){
      for(var i=0;i<firstTdArr.length;i++){
        //元素集合中存在匹配值时,显示匹配的记录,否则隐藏
        if (firstTdArr[i].innerHTML.toUpperCase().indexOf(filterVal) > -1) {
          firstTdArr[i].parentNode.style.display = "";
        }else{
          firstTdArr[i].parentNode.style.display = "none";
        }
      }
    },500);
  }else{
    //不满足匹配所需字符数量时,恢复匹配之前的模样
    for(var i=0;i<firstTdArr.length;i++){
      firstTdArr[i].parentNode.style.display = "";
    }
  }
}

<!-- HTML -->

<p><input type="text" οnkeyup="filterTable(this)"/></p>
<table id="oTable">
  <tr>
    <th>匹配数据</th>
    <th>数据项一</th>
    <th>数据项二</th>
    <th>数据项三</th>
  </tr>
  <tr>
    <td class="firstTd">JS前端数据多条件筛选</td>
    <td>11过滤table数据</td>
    <td>111过滤table数据</td>
    <td>1111过滤table数据</td>
  </tr>
  <tr>
    <td class="firstTd">程序员不会英语怎么行?</td>
    <td>22过滤table数据</td>
    <td>222过滤table数据</td>
    <td>2222过滤table数据</td>
  </tr>
  <tr>
    <td class="firstTd">前端代码编译后添加过滤</td>
    <td>33过滤table数据</td>
    <td>333过滤table数据</td>
    <td>3333过滤table数据</td>
  </tr>
  <tr>
    <td class="firstTd">大数据学习</td>
    <td>44过滤table数据</td>
    <td>444过滤table数据</td>
    <td>4444过滤table数据</td>
  </tr>
  <tr>
    <td class="firstTd">JS过滤HTML标签</td>
    <td>55过滤table数据</td>
    <td>555过滤table数据</td>
    <td>5555过滤table数据</td>
  </tr>
  <tr>
    <td class="firstTd">大数据你了解多少</td>
    <td>66过滤table数据</td>
    <td>666过滤table数据</td>
    <td>6666过滤table数据</td>
  </tr>
</table>

<!-- CSS3 -->

table{border: 1px solid #ccc;width: 900px;}
table tr:nth-child(odd){background:#F4F4F4;}
table tr:nth-child(even){background:#fff;}

<!-- 效果 -->

原生JS 实现的input输入时表格过滤操作示例

感兴趣的朋友可以使用在线HTML/CSS/JavaScript前端代码调试运行工具:http://tools.3water.com/code/WebCodeRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript表格(table)操作技巧大全》、《JavaScript操作DOM技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JS 容错处理代码, 屏蔽错误信息
Mar 09 Javascript
根据地区不同显示时间的javascript代码
Aug 13 Javascript
AngularJS基础学习笔记之简单介绍
May 10 Javascript
Angular 中 select指令用法详解
Sep 29 Javascript
javascript 利用arguments实现可变长参数
Nov 21 Javascript
浅析JavaScript动画模拟拖拽原理
Dec 09 Javascript
jQuery弹出窗口简单实现代码
Mar 09 Javascript
vue-cli+webpack项目 修改项目名称的方法
Feb 28 Javascript
vue中使用cropperjs的方法
Mar 01 Javascript
bootstrap中的导航条实例代码详解
May 20 Javascript
JS通过ajax + 多列布局 + 自动加载实现瀑布流效果
May 30 Javascript
在vue中实现嵌套页面(iframe)
Jul 30 Javascript
vue.js基于v-for实现批量渲染 Json数组对象列表数据示例
Aug 03 #Javascript
vue.js实现数据库的JSON数据输出渲染到html页面功能示例
Aug 03 #Javascript
jQuery实现的记住帐号密码功能完整示例
Aug 03 #jQuery
小程序中英文混合排序问题解决
Aug 02 #Javascript
详解JWT token心得与使用实例
Aug 02 #Javascript
详解使用JWT实现单点登录(完全跨域方案)
Aug 02 #Javascript
基于mpvue的简单弹窗组件mptoast使用详解
Aug 02 #Javascript
You might like
CPU步进是什么意思?i3-9100F B0步进和U0步进区别知识科普
2020/03/17 数码科技
IIS下配置Php+Mysql+zend的图文教程
2006/12/08 PHP
php实现在线生成条形码示例分享(条形码生成器)
2013/12/30 PHP
详解PHP对象的串行化与反串行化
2016/01/24 PHP
PHP中十六进制颜色与RGB颜色值互转的方法
2019/03/18 PHP
jquery遍历input取得input的name
2009/04/27 Javascript
WEB页子窗口(showModalDialog和showModelessDialog)使用说明
2009/10/25 Javascript
5种处理js跨域问题方法汇总
2014/12/04 Javascript
javascript实现加载xml文件的方法
2015/11/24 Javascript
jQuery 操作input中radio的技巧
2016/07/18 Javascript
vue.js学习笔记之绑定style样式和class列表
2016/10/31 Javascript
深入了解JavaScript的逻辑运算符(与、或)
2016/12/20 Javascript
谈谈第三方App接入微信登录 解读
2016/12/27 Javascript
vue v-on监听事件详解
2017/05/17 Javascript
JavaScript递归算法生成树形菜单
2017/08/15 Javascript
vue-router配合ElementUI实现导航的实例
2018/02/11 Javascript
vue源码学习之Object.defineProperty 对数组监听
2018/05/30 Javascript
详解easyui基于 layui.laydate日期扩展组件
2018/07/18 Javascript
解决vue中修改export default中脚本报一大堆错的问题
2018/08/27 Javascript
Javascript实现秒表倒计时功能
2018/11/17 Javascript
如何能分清npm cnpm npx nvm
2019/01/17 Javascript
Node.js web 应用如何封装到Docker容器中
2020/09/01 Javascript
[04:10]DOTA2英雄梦之声_第11期_圣堂刺客
2014/06/21 DOTA
Python轻量级ORM框架Peewee访问sqlite数据库的方法详解
2017/07/20 Python
使用pandas将numpy中的数组数据保存到csv文件的方法
2018/06/14 Python
基于PyQT实现区分左键双击和单击
2020/05/19 Python
Spring @Enable模块驱动原理及使用实例
2020/06/23 Python
Keras: model实现固定部分layer,训练部分layer操作
2020/06/28 Python
openCV提取图像中的矩形区域
2020/07/21 Python
详解Django关于StreamingHttpResponse与FileResponse文件下载的最优方法
2021/01/07 Python
2014年团总支工作总结
2014/11/21 职场文书
教你怎么用python爬取爱奇艺热门电影
2021/05/20 Python
雄兵连:第三季先行图公开,天使恶魔联合,银河之力的新力量
2021/06/11 国漫
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
python机器学习实现oneR算法(以鸢尾data为例)
2022/03/03 Python
vue3不同环境下实现配置代理
2022/05/25 Vue.js