jquery實現(xiàn)頁面關鍵詞高亮顯示的方法
更新時間:2015年03月12日 10:44:38 作者:pyawen
這篇文章主要介紹了jquery實現(xiàn)頁面關鍵詞高亮顯示的方法,實例分析了jQuery插件highlight實現(xiàn)高亮顯示的技巧,非常具有實用價值,需要的朋友可以參考下
本文實例講述了jquery實現(xiàn)頁面關鍵詞高亮顯示的方法。分享給大家供大家參考。具體分析如下:
通過jquery對頁面搜索關鍵詞進行高亮顯示
支持中文多詞頁面中高亮顯示
1. JavaScript代碼如下:
復制代碼 代碼如下:
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, // 清除原來高亮的結果
},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, // 清除原來高亮的結果
},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程序設計有所幫助。
您可能感興趣的文章:
- 基于jquery實現(xiàn)導航菜單高亮顯示(兩種方法)
- jQuery實現(xiàn)點擊后標記當前菜單位置(背景高亮菜單)效果
- jQuery編輯器KindEditor4.1.4代碼高亮顯示設置教程
- jquery(1.3.2) 高亮選中圖片邊框
- Jquery 高亮顯示文本中重要的關鍵字
- jquery實現(xiàn)帶復選框的表格行選中刪除時高亮顯示
- jQuery語法高亮插件支持各種程序源代碼語法著色加亮
- JQuery操作表格(隔行著色,高亮顯示,篩選數(shù)據(jù))
- jQuery實現(xiàn)當前頁面標簽高亮顯示的方法
- jQuery Json數(shù)據(jù)格式排版高亮插件json-viewer.js使用方法詳解
相關文章
基于jQuery的AJAX和JSON實現(xiàn)純html數(shù)據(jù)模板
jQuery內(nèi)置的AJAX功能,直接訪問后臺獲得JSON格式的數(shù)據(jù),從而實現(xiàn)純html數(shù)據(jù)模板,下面主要給大家介紹實現(xiàn)代碼,感興趣的朋友一起看下吧2016-08-08
jQuery通過控制節(jié)點實現(xiàn)僅在前臺通過get方法完成參數(shù)傳遞
這篇文章主要介紹了jQuery通過控制節(jié)點實現(xiàn)僅在前臺通過get方法完成參數(shù)傳遞的功能,實例分析了jQuery操作節(jié)點的技巧與控制前臺get方法傳遞參數(shù)的用法,具有一定參考借鑒價值,需要的朋友可以參考下2015-02-02

