基于jquery的給文章加入關(guān)鍵字鏈接
更新時間:2010年10月26日 13:35:30 作者:
最近在做一個網(wǎng)站,遇到需要給網(wǎng)站內(nèi)所有的文章加關(guān)鍵字鏈接的問題,我們在瀏覽一些網(wǎng)站的文章的時候,會發(fā)現(xiàn)文章里面的某些關(guān)鍵字是加了鏈接的,并且高亮顯示。
開始技術(shù)部門打算在后臺添加或者修改文章的時候,把文章里面的關(guān)鍵字替換為<a>標簽。但是這樣就出現(xiàn)一些問題
如果新添加一個關(guān)鍵字,是不是所有的文章又要重新過濾一邊。把新關(guān)鍵字替換掉。
如果修改了關(guān)鍵字的名字或者是修改了關(guān)鍵字的鏈接地址,那么又要重新過濾所有文件。
綜合了一些情況后,感覺使用后臺解決的方案行不通。于是我想到了前臺腳本解決
思路:
關(guān)鍵字鏈接的信息任然存放在數(shù)據(jù)庫中,在數(shù)據(jù)庫中有一些字段來保存關(guān)鍵字的信息。
當用戶添加,刪除,更新關(guān)鍵字的時候,在后臺生成一個js文件,格式如下:
var wordlinkdata='[{"WordLinkAlias":"wordlinkReplace4","WordLinkUrl":"http://www.dbjr.com.cn","WordLinkName":"你大爺21"},{"WordLinkAlias":"wordlinkReplace7","WordLinkUrl":"http://sc.jb51.net","WordLinkName":"電腦"}]'
wordlinkdata變量存放一些json數(shù)據(jù),這些數(shù)據(jù)是第二步的操作生成的。"WordLinkAlias"指的是關(guān)鍵詞的名稱,"WordLinkUrl"是關(guān)鍵字的鏈接。
在前臺頁面引用我們生成的js文件,我工作中使用的是jquery庫。我們需要做工作是替換文章中所有的關(guān)鍵字 。這樣,我們就需要用wordlinkdata的數(shù)據(jù)不斷的循環(huán)判斷。
$(document).ready(function() {
AddWordLink();
});
function AddWordLink(){
//給特殊詞加上鏈接
if (wordlinkdata != undefined && wordlinkdata != null) {
var content = $(".divArtContent");
if (content != null) {
var myobject = eval('(' + wordlinkdata + ')');
for (var i = 0; i < myobject.length; i++) {
content.highLight(myobject[i].WordLinkName, myobject[i].WordLinkUrl);
}
}
}
}
(function($) {
$.fn.highLight = function(str, url) {
if (str == undefined || str == " ") {
return this.find("a.divArtContentAlink").each(function() {
this.parentNode.firstChild.nodeName;
with (this.parentNode) {
replaceChild(this.firstChild, this);
normalize();
}
}).end();
} else {
$(this).each(function() {
elt = $(this).get(0);
elt.normalize();
$.each($.makeArray(elt.childNodes), function(i, node) {
if (node.nodeType == 3) {
var searchnode = node;
var pos = searchnode.data.indexOf(str);
if (pos >= 0) {//查找
var spannode = document.createElement('a');
spannode.className = 'divArtContentAlink';
spannode.href = url;
spannode.target = 'blank';
var middlebit = searchnode.splitText(pos);
var searchnode = middlebit.splitText(str.length);
var middleclone = middlebit.cloneNode(true);
spannode.appendChild(middleclone);
if (searchnode.parentNode != undefined)
searchnode.parentNode.replaceChild(spannode, middlebit);
}
} else {
$(node).highLight(str, url);
}
})
})
}
return $(this);
}
})(jQuery);
$.fn.highLight擴展是一個高亮擴展,我修改了一下,用來滿足需求,如果你需要修改鏈接的樣式,或者想自己創(chuàng)建別的元素,你可以修改以下的代碼
var spannode = document.createElement('a');
spannode.className = 'divArtContentAlink';
spannode.href = url;
spannode.target = 'blank';
不過這個方法的缺陷是,當關(guān)鍵字過多的時候(超過150個),頁面的速度會下降
總結(jié):這種方式的優(yōu)勢是,不需要對以前的文章做任何的修改,添加,刪除,修改很靈活
缺點是:一旦關(guān)鍵字太多,速度會下降。
大家如果遇到過這種情況,可以探討下。期待更好的解決方案
如果新添加一個關(guān)鍵字,是不是所有的文章又要重新過濾一邊。把新關(guān)鍵字替換掉。
如果修改了關(guān)鍵字的名字或者是修改了關(guān)鍵字的鏈接地址,那么又要重新過濾所有文件。
綜合了一些情況后,感覺使用后臺解決的方案行不通。于是我想到了前臺腳本解決
思路:
關(guān)鍵字鏈接的信息任然存放在數(shù)據(jù)庫中,在數(shù)據(jù)庫中有一些字段來保存關(guān)鍵字的信息。
當用戶添加,刪除,更新關(guān)鍵字的時候,在后臺生成一個js文件,格式如下:
復制代碼 代碼如下:
var wordlinkdata='[{"WordLinkAlias":"wordlinkReplace4","WordLinkUrl":"http://www.dbjr.com.cn","WordLinkName":"你大爺21"},{"WordLinkAlias":"wordlinkReplace7","WordLinkUrl":"http://sc.jb51.net","WordLinkName":"電腦"}]'
wordlinkdata變量存放一些json數(shù)據(jù),這些數(shù)據(jù)是第二步的操作生成的。"WordLinkAlias"指的是關(guān)鍵詞的名稱,"WordLinkUrl"是關(guān)鍵字的鏈接。
在前臺頁面引用我們生成的js文件,我工作中使用的是jquery庫。我們需要做工作是替換文章中所有的關(guān)鍵字 。這樣,我們就需要用wordlinkdata的數(shù)據(jù)不斷的循環(huán)判斷。
復制代碼 代碼如下:
$(document).ready(function() {
AddWordLink();
});
function AddWordLink(){
//給特殊詞加上鏈接
if (wordlinkdata != undefined && wordlinkdata != null) {
var content = $(".divArtContent");
if (content != null) {
var myobject = eval('(' + wordlinkdata + ')');
for (var i = 0; i < myobject.length; i++) {
content.highLight(myobject[i].WordLinkName, myobject[i].WordLinkUrl);
}
}
}
}
(function($) {
$.fn.highLight = function(str, url) {
if (str == undefined || str == " ") {
return this.find("a.divArtContentAlink").each(function() {
this.parentNode.firstChild.nodeName;
with (this.parentNode) {
replaceChild(this.firstChild, this);
normalize();
}
}).end();
} else {
$(this).each(function() {
elt = $(this).get(0);
elt.normalize();
$.each($.makeArray(elt.childNodes), function(i, node) {
if (node.nodeType == 3) {
var searchnode = node;
var pos = searchnode.data.indexOf(str);
if (pos >= 0) {//查找
var spannode = document.createElement('a');
spannode.className = 'divArtContentAlink';
spannode.href = url;
spannode.target = 'blank';
var middlebit = searchnode.splitText(pos);
var searchnode = middlebit.splitText(str.length);
var middleclone = middlebit.cloneNode(true);
spannode.appendChild(middleclone);
if (searchnode.parentNode != undefined)
searchnode.parentNode.replaceChild(spannode, middlebit);
}
} else {
$(node).highLight(str, url);
}
})
})
}
return $(this);
}
})(jQuery);
$.fn.highLight擴展是一個高亮擴展,我修改了一下,用來滿足需求,如果你需要修改鏈接的樣式,或者想自己創(chuàng)建別的元素,你可以修改以下的代碼
復制代碼 代碼如下:
var spannode = document.createElement('a');
spannode.className = 'divArtContentAlink';
spannode.href = url;
spannode.target = 'blank';
不過這個方法的缺陷是,當關(guān)鍵字過多的時候(超過150個),頁面的速度會下降
總結(jié):這種方式的優(yōu)勢是,不需要對以前的文章做任何的修改,添加,刪除,修改很靈活
缺點是:一旦關(guān)鍵字太多,速度會下降。
大家如果遇到過這種情況,可以探討下。期待更好的解決方案
您可能感興趣的文章:
- 用JS讓文章內(nèi)容指定的關(guān)鍵字加亮
- 一個對于js this關(guān)鍵字的問題
- Jquery 高亮顯示文本中重要的關(guān)鍵字
- jquery 關(guān)鍵字“拖曳搜索”之“拖曳”以及 圖片“提示自適應(yīng)放大”效果 的實現(xiàn)
- jquery 結(jié)合C#后臺的數(shù)組對文章的關(guān)鍵字自動添加鏈接的代碼
- JQuery+JS實現(xiàn)仿百度搜索結(jié)果中關(guān)鍵字變色效果
- 仿百度的關(guān)鍵詞匹配搜索示例
- JS實現(xiàn)關(guān)鍵字搜索時的相關(guān)下拉字段效果
- Python抓取淘寶下拉框關(guān)鍵詞的方法
- jQuery過濾HTML標簽并高亮顯示關(guān)鍵字的方法
- 基于jQuery實現(xiàn)搜索關(guān)鍵字自動匹配功能
相關(guān)文章
jQuery的3種請求方式$.post,$.get,$.getJSON
這篇文章主要介紹了jQuery的3種請求方式$.post,$.get,$.getJSON,需要的朋友可以參考下2014-03-03
EasyUI中datagrid在ie下reload失敗解決方案
這篇文章主要介紹了EasyUI中datagrid在ie下reload失敗解決方案,結(jié)合網(wǎng)上搜集來的幾種方案,最終解決了這個問題,分享給大家,希望對大家能夠有所幫助。2015-03-03
JQuery一種取同級值的方式(比如你在GridView中)
JQuery一種取同級值的方式 比如你在GridView中,實現(xiàn)代碼如下,需要的朋友可以參考下2012-03-03
PHP+MySQL+jQuery隨意拖動層并即時保存拖動位置實例講解
這篇文章主要介紹了PHP+MySQL+jQuery隨意拖動層并即時保存拖動位置的實現(xiàn)方法,感興趣的小伙伴們可以參考一下2015-10-10
jQuery插件easyUI實現(xiàn)通過JS顯示Dialog的方法
這篇文章主要介紹了jQuery插件easyUI實現(xiàn)通過JS顯示Dialog的方法,實例分析了jQuery插件easyUI彈出Dialog的具體實現(xiàn)技巧,需要的朋友可以參考下2016-09-09

