如何通过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 ...
随机推荐
- 装有Win7系统的电脑在局域网不能共享的解决方案
Win7系统的网络功能比XP有了进一步的增强,使用起来也相对清晰.但是由于做了很多表面优化的工作,使得底层的网络设置对于习惯了XP系统的人来说变得很不适应,其中局域网组建就是一个很大的问题.默认安装系 ...
- magic_quotes_runtime(魔术引号开关)
我们可以通过以下代码来探测php环境中magic_quotes_runtime是否开启: magic_runtime.php 源代码如下: <?php //当magic_quotes_runti ...
- Tomcat Server 原理
构成: 1.server代表整个catalina serverlet容器 2.service:由一个或多个connector以及一个共享的engine处理引擎组成 3.connector 在指定端口上 ...
- CSS样式表其它知识点
1.cursor:pointer鼠标放到上面变形状,pointer为手 2.margin:auto 页面居中 3.显示方式:dispaly:none不显示/block 块换行/inline在一行上,宽 ...
- android开发:点击缩略图查看大图
android中点击缩略图查看大图的方法一般有两种,一种是想新浪微博list页面那样,弹出一个窗口显示大图(原activity为背景).另一种就是直接打开一个新的activity显示大图. 1.第一种 ...
- JQM 页面滚动加载
1 应用场景:文章比较长,只加载部分,当到页面底部触发获取更多数据. 2 如图,监听滚动条的位置,触发事件,转化为求X的长度, 3 实例代码: //滚动条到底加载更多 $(document).on(& ...
- ASP.NET得到系统相关信息
1. 在ASP.NET中专用属性: 获取服务器电脑名:Page.Server.ManchineName 获取用户信息:Page.User 获取客户端电脑名:Page.Request.UserHos ...
- Windows环境下使用Cmake ndk编译fdk-aac
一.废话 最近学习,第一步就是编译.我们需要编译FFmpag,x264,fdk_aac,下面是x264,网上说的很多都是几百年前的,我亲测完美可用 还是那句话 我能力有限,但是我希望我写的东西能够让 ...
- css-a:visited
如下代码: <a href="#">链接地址</a> 如果属性 href的设置为'#',则鼠标滑过(即使没有点击',也算成'visited'.而对于 hre ...
- js跨浏览器事件对象、事件处理程序
项目中有时候会不用jquery这么好用的框架,需要自己封装一些事件对象和事件处理程序,像封装AJAX那样:这里面考虑最多的还是浏览器的兼容问题,原生js封装如下:var EventUtil={ //节 ...