给你推荐通过jquery来实现高亮关键词。jquery.textSearch-1.0.js代码:

  1. (function($){
  2. $.fn.textSearch =function(str,options){
  3. var defaults ={
  4. divFlag:true,
  5. divStr:" ",
  6. markClass:"",
  7. markColor:"red",
  8. nullReport:true,
  9. callback:function(){
  10. returnfalse;
  11. }
  12. };
  13. var sets = $.extend({}, defaults, options ||{}), clStr;
  14. if(sets.markClass){
  15. clStr ="class='"+sets.markClass+"'";
  16. }else{
  17. clStr ="style='color:"+sets.markColor+";'";
  18. }
  19. //对前一次高亮处理的文字还原
  20. $("span[rel='mark']").removeAttr("class").removeAttr("style").removeAttr("rel");
  21. //字符串正则表达式关键字转化
  22. $.regTrim =function(s){
  23. var imp =/[\^\.\\\|\(\)\*\+\-\$\[\]\?]/g;
  24. var imp_c ={};
  25. imp_c["^"]="\\^";
  26. imp_c["."]="\\.";
  27. imp_c["\\"]="\\\\";
  28. imp_c["|"]="\\|";
  29. imp_c["("]="\\(";
  30. imp_c[")"]="\\)";
  31. imp_c["*"]="\\*";
  32. imp_c["+"]="\\+";
  33. imp_c["-"]="\\-";
  34. imp_c["$"]="\$";
  35. imp_c["["]="\\[";
  36. imp_c["]"]="\\]";
  37. imp_c["?"]="\\?";
  38. s = s.replace(imp,function(o){
  39. return imp_c[o];
  40. });
  41. return s;
  42. };
  43. $(this).each(function(){
  44. var t = $(this);
  45. str = $.trim(str);
  46. if(str ===""){
  47. alert("关键字为空");
  48. returnfalse;
  49. }else{
  50. //将关键字push到数组之中
  51. var arr =[];
  52. if(sets.divFlag){
  53. arr = str.split(sets.divStr);
  54. }else{
  55. arr.push(str);
  56. }
  57. }
  58. var v_html = t.html();
  59. //删除注释
  60. v_html = v_html.replace(/<!--(?:.*)\-->/g,"");
  61. //将HTML代码支离为HTML片段和文字片段,其中文字片段用于正则替换处理,而HTML片段置之不理
  62. var tags =/[^<>]+|<(\/?)([A-Za-z]+)([^<>]*)>/g;
  63. var a = v_html.match(tags), test =0;
  64. $.each(a,function(i, c){
  65. if(!/<(?:.|\s)*?>/.test(c)){//非标签
  66. //开始执行替换
  67. $.each(arr,function(index, con){
  68. if(con ===""){return;}
  69. var reg =newRegExp($.regTrim(con),"g");
  70. if(reg.test(c)){
  71. //正则替换
  72. c = c.replace(reg,"♂"+con+"♀");
  73. test =1;
  74. }
  75. });
  76. c = c.replace(/♂/g,"<span rel='mark' "+clStr+">").replace(/♀/g,"</span>");
  77. a[i]= c;
  78. }
  79. });
  80. //将支离数组重新组成字符串
  81. var new_html = a.join("");
  82. $(this).html(new_html);
  83. if(test ===0&& sets.nullReport){
  84. alert("没有搜索结果");
  85. returnfalse;
  86. }
  87. //执行回调函数
  88. sets.callback();
  89. });
  90. };
  91. })(jQuery);

使用方法是textSearch,具体为:$(选择器). textSearch(String,可选参数)。例如,

  1. $("body").textSearch("世界杯");
 

表示的含义就是查询并红色高亮标注body标签下的所有的“世界杯”这个关键字,也就是页面下高亮标注所有的“世界杯”文字。又如:

  1. $(".test").textSearch("空姐 凤姐 芙蓉姐",{markColor:"blue"});

则表示class中有test样式的所有标签下的“空姐”,“凤姐”,“芙蓉姐”文字用蓝色高亮标注。

我使用的过程为:(需要同时引入下面两个js文件才能正常运行)

<script type="text/javascript" src="jquery-2.0.0.js"></script>
<script type="text/javascript" src="jquery.textSearch-1.0.js"></script>
<script type="text/javascript">
$(function(){
var v = $("#txtSearchKeyword").val();   //获取id为txtSearchKeyword的text值赋给v  也可以使用request传递的参数:var v = "<%=q1%>";
$("#searchTextTest").textSearch(v);     //将id为searchTextTest的文本中包含v的高亮显示
return false;
});

</script>

详细用法请参考:http://www.zhangxinxu.com/wordpress/?p=888

如何通过js使搜索关键词高亮的更多相关文章

  1. 微信小程序--搜索关键词高亮

    代码地址如下:http://www.demodashi.com/demo/14249.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...

  2. 微信小程序实现搜索关键词高亮

    目录 1,前言 2,思路 3,代码逻辑 1,前言 项目中碰到一个需求,搜索数据并且关键词要高亮显示,接到需求,马上开干.先上效果图.源码已经做成了小程序代码片段,放入了GitHub了,文章底部有源码链 ...

  3. 和我一起打造个简单搜索之SpringDataElasticSearch关键词高亮

    前面几篇文章详细讲解了 ElasticSearch 的搭建以及使用 SpringDataElasticSearch 来完成搜索查询,但是搜索一般都会有搜索关键字高亮的功能,今天我们把它给加上. 系列文 ...

  4. js 获取百度搜索关键词的代码

    有可能有时候我们会用到在百度搜什么关键词进来我们的网站的,所有我们又想拿到用户搜索的关键词. 这是我研究了半天所得出的办法.话不多说直接贴代码 <script> function quer ...

  5. 从零搭建 ES 搜索服务(五)搜索结果高亮

    一.前言 在实际使用中搜索结果中的关键词前端通常会以特殊形式展示,比如标记为红色使人一目了然.我们可以通过 ES 提供的高亮功能实现此效果. 二.代码实现 前文查询是通过一个继承 Elasticsea ...

  6. 在 Angular 中实现搜索关键字高亮

    在 Angular 中,我们不应该试图直接修改 DOM 的内容,当需要更新 DOM 内容的时候,应该修改的其实是我们的数据模型,也就是 $scope 中的数据,Angular 会帮助我们将修改之后的数 ...

  7. Django Haystack 全文检索与关键词高亮

    Django Haystack 简介 django-haystack 是一个专门提供搜索功能的 django 第三方应用,它支持 Solr.Elasticsearch.Whoosh.Xapian 等多 ...

  8. jQuery的搜索关键词自动匹配插件

    相信许多人都会用过搜索栏自动匹配关键词的功能,无论是像google的专业搜索引擎,还是普通的网站,现在许多都用上了这种关键词匹配技术,本文介绍的用jQuery实现的关键词匹配技术,当然要整合到自己的系 ...

  9. jQuery实现页面关键词高亮

    示例代码,关键位置做了注释,请查看代码: <html> <head> <title>jQuery实现页面关键词高亮</title> <style ...

随机推荐

  1. hdu2091JAVA

    空心三角形 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. AndroidUniversalImageLoader网络图片加载

    1.功能概要 Android-Universal-Image-Loader是一个开源的UI组件程序,该项目的目的是提供一个可重复使用的仪器为异步图像加载,缓存和显示. (1).使用多线程加载图片(2) ...

  3. WebService学习笔记系列(二)

    soap(简单对象访问协议),它是在http基础之上传递xml格式数据的协议.soap协议分为两个版本,soap1.1和soap1.2. 在学习webservice时我们有一个必备工具叫做tcpmon ...

  4. Java基础知识强化之网络编程笔记06:TCP之TCP协议发送数据 和 接收数据

    1. TCP协议发送数据 和 接收数据 TCP协议接收数据:• 创建接收端的Socket对象• 监听客户端连接.返回一个对应的Socket对象• 获取输入流,读取数据显示在控制台• 释放资源 TCP协 ...

  5. GUI编程笔记(java)05:GUI事件监听机制原理和举例说明

    1.事件监听机制:       A:事件源          事件发生的地方       B:事件             就是要发生的事情       C:事件处理       就是针对发生的事情做 ...

  6. CSS自动控制图片大小的代码

    img { max-width: 800px; height: auto; } 代码中的max-width:800px限制图片的最大宽度为800像素,而下面的hight:auto很关键,可以保证图片有 ...

  7. C#语法糖之第四篇: 扩展方法

    今天继续分享C#4.0语法糖的扩展方法,这个方法也是我本人比较喜欢的方法.大家先想想比如我们以前写的原始类型不能满足现在的需求,而需要在该类型中添加新的方法来实现时大家会怎么做.我先说一下我没有学习到 ...

  8. 文件夹IsShow字段为空

    IsShow为YesNo字段,默认值为Yes:在Library中新建一个文件的时候会给出默认值yes,但是新建一个文件夹的时候,默认为空,所以f.Item["IsShow"]为空, ...

  9. Hadoop_Block的几种状态_DataNode

    在Hadoop 2.0 中HDFS 引入了 append 和 hflush 功能之后, 需要为 数据块增加新的状态 来尽最大可能的保证数据的一致性. 参阅文档: http://files.cnblog ...

  10. 【转】ASP.NET MVC教程

    转自:http://www.cnblogs.com/QLeelulu/category/123326.html ASP.NET MVC的最佳实践与性能优化的文章 摘要: 就一些文章链接,就不多废话了. ...