如何通过js使搜索关键词高亮
给你推荐通过jquery来实现高亮关键词。jquery.textSearch-1.0.js代码:
- (function($){
- $.fn.textSearch =function(str,options){
- var defaults ={
- divFlag:true,
- divStr:" ",
- markClass:"",
- markColor:"red",
- nullReport:true,
- callback:function(){
- returnfalse;
- }
- };
- var sets = $.extend({}, defaults, options ||{}), clStr;
- if(sets.markClass){
- clStr ="class='"+sets.markClass+"'";
- }else{
- clStr ="style='color:"+sets.markColor+";'";
- }
- //对前一次高亮处理的文字还原
- $("span[rel='mark']").removeAttr("class").removeAttr("style").removeAttr("rel");
- //字符串正则表达式关键字转化
- $.regTrim =function(s){
- var imp =/[\^\.\\\|\(\)\*\+\-\$\[\]\?]/g;
- var imp_c ={};
- imp_c["^"]="\\^";
- imp_c["."]="\\.";
- imp_c["\\"]="\\\\";
- imp_c["|"]="\\|";
- imp_c["("]="\\(";
- imp_c[")"]="\\)";
- imp_c["*"]="\\*";
- imp_c["+"]="\\+";
- imp_c["-"]="\\-";
- imp_c["$"]="\$";
- imp_c["["]="\\[";
- imp_c["]"]="\\]";
- imp_c["?"]="\\?";
- s = s.replace(imp,function(o){
- return imp_c[o];
- });
- return s;
- };
- $(this).each(function(){
- var t = $(this);
- str = $.trim(str);
- if(str ===""){
- alert("关键字为空");
- returnfalse;
- }else{
- //将关键字push到数组之中
- var arr =[];
- if(sets.divFlag){
- arr = str.split(sets.divStr);
- }else{
- arr.push(str);
- }
- }
- var v_html = t.html();
- //删除注释
- v_html = v_html.replace(/<!--(?:.*)\-->/g,"");
- //将HTML代码支离为HTML片段和文字片段,其中文字片段用于正则替换处理,而HTML片段置之不理
- var tags =/[^<>]+|<(\/?)([A-Za-z]+)([^<>]*)>/g;
- var a = v_html.match(tags), test =0;
- $.each(a,function(i, c){
- if(!/<(?:.|\s)*?>/.test(c)){//非标签
- //开始执行替换
- $.each(arr,function(index, con){
- if(con ===""){return;}
- var reg =newRegExp($.regTrim(con),"g");
- if(reg.test(c)){
- //正则替换
- c = c.replace(reg,"♂"+con+"♀");
- test =1;
- }
- });
- c = c.replace(/♂/g,"<span rel='mark' "+clStr+">").replace(/♀/g,"</span>");
- a[i]= c;
- }
- });
- //将支离数组重新组成字符串
- var new_html = a.join("");
- $(this).html(new_html);
- if(test ===0&& sets.nullReport){
- alert("没有搜索结果");
- returnfalse;
- }
- //执行回调函数
- sets.callback();
- });
- };
- })(jQuery);
使用方法是textSearch,具体为:$(选择器). textSearch(String,可选参数)。例如,
- $("body").textSearch("世界杯");
表示的含义就是查询并红色高亮标注body标签下的所有的“世界杯”这个关键字,也就是页面下高亮标注所有的“世界杯”文字。又如:
- $(".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使搜索关键词高亮的更多相关文章
- 微信小程序--搜索关键词高亮
代码地址如下:http://www.demodashi.com/demo/14249.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...
- 微信小程序实现搜索关键词高亮
目录 1,前言 2,思路 3,代码逻辑 1,前言 项目中碰到一个需求,搜索数据并且关键词要高亮显示,接到需求,马上开干.先上效果图.源码已经做成了小程序代码片段,放入了GitHub了,文章底部有源码链 ...
- 和我一起打造个简单搜索之SpringDataElasticSearch关键词高亮
前面几篇文章详细讲解了 ElasticSearch 的搭建以及使用 SpringDataElasticSearch 来完成搜索查询,但是搜索一般都会有搜索关键字高亮的功能,今天我们把它给加上. 系列文 ...
- js 获取百度搜索关键词的代码
有可能有时候我们会用到在百度搜什么关键词进来我们的网站的,所有我们又想拿到用户搜索的关键词. 这是我研究了半天所得出的办法.话不多说直接贴代码 <script> function quer ...
- 从零搭建 ES 搜索服务(五)搜索结果高亮
一.前言 在实际使用中搜索结果中的关键词前端通常会以特殊形式展示,比如标记为红色使人一目了然.我们可以通过 ES 提供的高亮功能实现此效果. 二.代码实现 前文查询是通过一个继承 Elasticsea ...
- 在 Angular 中实现搜索关键字高亮
在 Angular 中,我们不应该试图直接修改 DOM 的内容,当需要更新 DOM 内容的时候,应该修改的其实是我们的数据模型,也就是 $scope 中的数据,Angular 会帮助我们将修改之后的数 ...
- Django Haystack 全文检索与关键词高亮
Django Haystack 简介 django-haystack 是一个专门提供搜索功能的 django 第三方应用,它支持 Solr.Elasticsearch.Whoosh.Xapian 等多 ...
- jQuery的搜索关键词自动匹配插件
相信许多人都会用过搜索栏自动匹配关键词的功能,无论是像google的专业搜索引擎,还是普通的网站,现在许多都用上了这种关键词匹配技术,本文介绍的用jQuery实现的关键词匹配技术,当然要整合到自己的系 ...
- jQuery实现页面关键词高亮
示例代码,关键位置做了注释,请查看代码: <html> <head> <title>jQuery实现页面关键词高亮</title> <style ...
随机推荐
- HDU2056JAVA
Rectangles Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- Amazon S3 上传文件 SSL23_GET_SERVER_HELLO握手错误
题外话:今天偶尔来逛逛,发现我真是懒到家了.居然有半年前的留言我都没有来看过,真对不起留言的同学,希望他的问题已经解决了. 这两三天一直被亚马逊S3上传文件的问题困扰着,直到昨天晚上终于搞定了,工作群 ...
- php yield
php中关于 yield 关键字的介绍[点击查看] <?php function gen_one_to_three() { for ($i = 1; $i <= 3; $i++) { // ...
- 超过2T,磁盘分区
MBR:MBR分区表(即主引导记录)大家都很熟悉.所支持的最大卷:2T,而且对分区有限制:最多4个主分区或3个主分区加一个扩展分区 GPT: GPT(即GUID分区表).是源自EFI标准的一种较新的磁 ...
- awk用法举例
awk文本分割输出工具(按列输出工具) awk [options] ' PATTERN { action } ' file1, file2, ... 内置变量: FS:field separator, ...
- Spring for Apache Kafka
官方文档详见:http://docs.spring.io/spring-kafka/docs/1.0.2.RELEASE/reference/htmlsingle/ Authors Gary Russ ...
- jquery easyui textbox onblur事件,textbox blur事件无效解决方案
jquery easyui textbox onblur事件,textbox blur事件无效解决方案 >>>>>>>>>>>> ...
- asp.net 使用IHttpModule 做权限检查 登录超时检查(转)
IHttpModule 权限 检查 登录超时检查 这样就不需要每个页面都做一次检查 也不需要继承任何父类. using System;using System.Collections.Generic; ...
- Java中OutOfMemoryError(内存溢出)的情况及解决办法
java.lang.OutOfMemoryError: Java heap space // TODO Auto-generated method stub Vector v = new Vector ...
- 【原创】Android 对话框的使用
对话框即Dialog .google的官方解释:A dialog is usually a small window that appears in front of the current Acti ...