全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript实现的搜索及高亮显示功能示例

本文实例讲述了JavaScript实现的搜索及高亮显示功能。分享给大家供大家参考,具体如下:

情景: 用来筛选列表中的数据, 由于单条数据很简短, 没有用php+mysql去实现筛选功能, 只用javascript进行筛选, 匹配的高亮, 或者将不匹配的隐藏掉

效果图:

html:

<div class="contracts-header">名称: <input type="text" value="" id="search_contract_name"></div>
<div class="contracts-header">代码: <input type="text" value="" id="search_contract_code" placeholder="不区分大小写"></div>
<div class="contracts-header"><button onclick="search()">查找</button></div>
<div id="contracts-list">
  <ul>
  <li><input type="checkbox" name="contract[]" value="code|name" /><span>name(code)</span></li>
  <li><input type="checkbox" name="contract[]" value="code|name" /><span>name(code)</span></li>
  </ul>
</div>

javascript:

function search()
{
  var search_contract_name = $("#search_contract_name").val();
  var search_contract_code = $("#search_contract_code").val();
  if (search_contract_name && search_contract_code) { //两个输入框都有值
    search_contract_code = search_contract_code.toLowerCase(); //不区分大小写, 全部转换为小写, 下同
    $("input[name='contract[]']").each(
        function () {
          var code_name = this.value;
          var search_code = code_name.toLowerCase().indexOf(search_contract_code); 
          var search_name = code_name.toLowerCase().indexOf(search_contract_name);
          if (search_code >=0 && search_name >=0 ) {
            // this.nextSibling.style.backgroundColor = "#FFDEAD"; //高亮匹配到的
            this.parentNode.style.display = 'block';
          } else {
            // this.nextSibling.style.backgroundColor = "";
            this.parentNode.style.display = 'none'; //隐藏不匹配的
          }
        }
    );
  } else if(search_contract_name || search_contract_code) { //只有一个输入框有值
    search_contract_name = search_contract_name.length ? search_contract_name : 'xxx'; //默认为xxx是因为不可能存在xxx
    search_contract_code = search_contract_code.length ? search_contract_code.toLowerCase() : 'xxx';
    $("input[name='contract[]']").each(
      function () {
        var code_name = this.value;
        var search_code = code_name.toLowerCase().indexOf(search_contract_code);
        var search_name = code_name.toLowerCase().indexOf(search_contract_name);
        if (search_code >=0 || search_name >=0 ) {
          // this.nextSibling.style.backgroundColor = "#FFDEAD";
          this.parentNode.style.display = 'block';
        } else {
          // this.nextSibling.style.backgroundColor = "";
          this.parentNode.style.display = 'none';
        }
      }
    );
  }
}

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数据结构与算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

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


# JavaScript  # 搜索  # 高亮  # 基于jquery实现导航菜单高亮显示(两种方法)  # vuejs 切换导航条高亮(路由菜单高亮)的方法示例  # 用js查找法实现当前栏目的高亮显示的代码  # 使用JS实现导航切换时高亮显示的示例讲解  # 输入框  # 都有  # 是因为  # 不可能  # 相关内容  # 遍历  # 感兴趣  # 数据结构  # 给大家  # 只有一个  # 将不  # 更多关于  # 转换为  # 所述  # 程序设计  # 默认为  # 单条  # 不匹配  # 讲述了  # 列表中 


相关文章: ,有什么在线背英语单词效率比较高的网站?  如何在云主机快速搭建网站站点?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  网站制作服务平台,有什么网站可以发布本地服务信息?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  c# 服务器GC和工作站GC的区别和设置  如何设置并定期更换建站之星安全管理员密码?  如何使用Golang table-driven基准测试_多组数据测量函数效率  PHP 500报错的快速解决方法  招贴海报怎么做,什么是海报招贴?  建站ABC备案流程中有哪些关键注意事项?  建站之星后台密码遗忘?如何快速找回?  中山网站制作网页,中山新生登记系统登记流程?  如何快速搭建高效服务器建站系统?  如何通过西部建站助手安装IIS服务器?  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  建站之星安装失败:服务器环境不兼容?  建站之星安装步骤有哪些常见问题?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  家庭服务器如何搭建个人网站?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  如何获取上海专业网站定制建站电话?  如何撰写建站申请书?关键要点有哪些?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  ,南京靠谱的征婚网站?  威客平台建站流程解析:高效搭建教程与设计优化方案  图册素材网站设计制作软件,图册的导出方式有几种?  建站之星备案流程有哪些注意事项?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何在阿里云香港服务器快速搭建网站?  如何通过商城自助建站源码实现零基础高效建站?  建站为何优先选择香港服务器?  如何快速重置建站主机并恢复默认配置?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何用西部建站助手快速创建专业网站?  网站制作员失业,怎样查看自己网站的注册者?  建站之星代理如何优化在线客服效率?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  如何基于PHP生成高效IDC网络公司建站源码?  如何高效配置IIS服务器搭建网站?  北京企业网站设计制作公司,北京铁路集团官方网站?  linux top下的 minerd 木马清除方法  建站上传速度慢?如何优化加速网站加载效率?  Python lxml的etree和ElementTree有什么区别  音响网站制作视频教程,隆霸音响官方网站?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  制作网站的软件免费下载,免费制作app哪个平台好? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。