本文实例讲述了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小时内与您取得联系。