jquery實現(xiàn)頁面關(guān)鍵詞高亮顯示的方法
更新時間:2015年03月12日 10:44:38 作者:pyawen
這篇文章主要介紹了jquery實現(xiàn)頁面關(guān)鍵詞高亮顯示的方法,實例分析了jQuery插件highlight實現(xiàn)高亮顯示的技巧,非常具有實用價值,需要的朋友可以參考下
本文實例講述了jquery實現(xiàn)頁面關(guān)鍵詞高亮顯示的方法。分享給大家供大家參考。具體分析如下:
通過jquery對頁面搜索關(guān)鍵詞進(jìn)行高亮顯示
支持中文多詞頁面中高亮顯示
1. JavaScript代碼如下:
復(fù)制代碼 代碼如下:
jQuery.fn.extend({
highlight: function(search, configs){
if(typeof(search) == 'undefined') return;
var configs = jQuery.extend({
insensitive: 1, //是否匹配大小寫 0匹配 1不匹配
hls_class: 'highlight', // 高亮后的class
clear_last: true, // 清除原來高亮的結(jié)果
},configs);
if(configs.clear_last) {
$(this).find("strong."+configs.hls_class).each(function(){
$(this).after($(this).text());
$(this).remove();
})
}
return this.each(function() {
if(typeof(search) == "string") {
$(this).highregx(search,configs);
} else if (search.constructor === Array ) {
for(var query in search){
var search_str = $.trim(search[query]);
if(search_str != "") $(this).highregx(search_str,configs);
}
}
});
},
highregx: function(query,configs){
query = this.unicode(query);
var regex = new RegExp("(<[^>]*>)|("+ query +")", configs.insensitive ? "ig" : "g");
this.html(this.html().replace(regex, function(a, b, c){
return (a.charAt(0) == "<") ? a : "<strong class=\""+ configs.hls_class +"\">" + c + "</strong>";
}));
},
unicode: function(s){
var len=s.length;
var rs="";
s = s.replace(/([-.*+?^${}()|[\]\/\\])/g,"\\$1");
for(var i=0;i<len;i++){
if(s.charCodeAt(i) > 255)
rs+="\\u"+ s.charCodeAt(i).toString(16);
else rs += s.charAt(i);
}
return rs;
}
});
highlight: function(search, configs){
if(typeof(search) == 'undefined') return;
var configs = jQuery.extend({
insensitive: 1, //是否匹配大小寫 0匹配 1不匹配
hls_class: 'highlight', // 高亮后的class
clear_last: true, // 清除原來高亮的結(jié)果
},configs);
if(configs.clear_last) {
$(this).find("strong."+configs.hls_class).each(function(){
$(this).after($(this).text());
$(this).remove();
})
}
return this.each(function() {
if(typeof(search) == "string") {
$(this).highregx(search,configs);
} else if (search.constructor === Array ) {
for(var query in search){
var search_str = $.trim(search[query]);
if(search_str != "") $(this).highregx(search_str,configs);
}
}
});
},
highregx: function(query,configs){
query = this.unicode(query);
var regex = new RegExp("(<[^>]*>)|("+ query +")", configs.insensitive ? "ig" : "g");
this.html(this.html().replace(regex, function(a, b, c){
return (a.charAt(0) == "<") ? a : "<strong class=\""+ configs.hls_class +"\">" + c + "</strong>";
}));
},
unicode: function(s){
var len=s.length;
var rs="";
s = s.replace(/([-.*+?^${}()|[\]\/\\])/g,"\\$1");
for(var i=0;i<len;i++){
if(s.charCodeAt(i) > 255)
rs+="\\u"+ s.charCodeAt(i).toString(16);
else rs += s.charAt(i);
}
return rs;
}
});
2.highlight插件點擊此處下載。
希望本文所述對大家的jQuery程序設(shè)計有所幫助。
您可能感興趣的文章:
- 基于jquery實現(xiàn)導(dǎo)航菜單高亮顯示(兩種方法)
- jQuery實現(xiàn)點擊后標(biāo)記當(dāng)前菜單位置(背景高亮菜單)效果
- jQuery編輯器KindEditor4.1.4代碼高亮顯示設(shè)置教程
- jquery(1.3.2) 高亮選中圖片邊框
- Jquery 高亮顯示文本中重要的關(guān)鍵字
- jquery實現(xiàn)帶復(fù)選框的表格行選中刪除時高亮顯示
- jQuery語法高亮插件支持各種程序源代碼語法著色加亮
- JQuery操作表格(隔行著色,高亮顯示,篩選數(shù)據(jù))
- jQuery實現(xiàn)當(dāng)前頁面標(biāo)簽高亮顯示的方法
- jQuery Json數(shù)據(jù)格式排版高亮插件json-viewer.js使用方法詳解
相關(guān)文章
學(xué)習(xí)jquery必備 api中英文對照的chm手冊 下載
學(xué)習(xí)jquery必備 api中英文對照的chm手冊 下載...2007-05-05jQuery操作Select的Option上下移動及移除添加等等
jQuery操作Select Option:向上移動選中的option、向下移動選中的option、移除選中的option、獲取所有的option值、添加option等等,下面有個不錯的示例,感興趣的朋友不要錯過2013-11-11