java 关键字高亮_关于搜索功能的关键字高亮显示是如何实现的

jq中的实现方法:

//搜索结果高亮显示

function encode(s) {

return s.replace(/&/g, "&").replace(//g, ">").replace(/([\\\.\*\[\]\(\)\$\^])/g, "\\$1");

}

function decode(s) {

return s.replace(/\\([\\\.\*\[\]\(\)\$\^])/g, "$1").replace(/>/g, ">").replace(/

}

function loopSearch(s, obj) {

var cnt = 0;

if (obj.nodeType == 3) {

cnt = replace(s, obj);

return cnt;

}

for (var i = 0, c; c = obj.childNodes[i]; i++) {

if (!c.className || c.className != "highlight")

cnt += loopSearch(s, c);

}

return cnt;

}

function replace(s, dest) {

var r = new RegExp(s, "g");

var tm = null;

var t = dest.nodeValue;

var cnt = 0;

if (tm = t.match(r)) {

cnt = tm.length;

t = t.replace(r, "{searchHL}" + decode(s) + "{/searchHL}")

dest.nodeValue = t;

}

return cnt;

}

function highlight(s,l) {

if (s.length == 0) {

return false;

}

s = encode(s).toLowerCase();

var obj_li = $('#'+l+'').find('h4');//显示内容的容器id下的标题h4,可以改成你自己用的其他的标签

obj_li.each(function (i, o) {

var t = o.innerHTML.replace(/([^<>]*)/gi, "$1");

o.innerHTML = t;

var cnt = loopSearch(s, o);

t = o.innerHTML

var r = /{searchHL}(({(?!\/searchHL})|[^{])*){\/searchHL}/g

t = t.replace(r, "$1");

o.innerHTML = t;

});

}

使用:

例如:你的内容是显示在这个div#aaaa内,搜索内容的标题是h4标签显示的,那么调用上面的方法:highlight('呵呵','aaaa'),结果内容中的呵呵就显示高亮了。

抛砖引玉

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值