基于jquery的給文章加入關(guān)鍵字鏈接
如果新添加一個(gè)關(guān)鍵字,是不是所有的文章又要重新過(guò)濾一邊。把新關(guān)鍵字替換掉。
如果修改了關(guān)鍵字的名字或者是修改了關(guān)鍵字的鏈接地址,那么又要重新過(guò)濾所有文件。
綜合了一些情況后,感覺(jué)使用后臺(tái)解決的方案行不通。于是我想到了前臺(tái)腳本解決
思路:
關(guān)鍵字鏈接的信息任然存放在數(shù)據(jù)庫(kù)中,在數(shù)據(jù)庫(kù)中有一些字段來(lái)保存關(guān)鍵字的信息。
當(dāng)用戶添加,刪除,更新關(guān)鍵字的時(shí)候,在后臺(tái)生成一個(gè)js文件,格式如下:
var wordlinkdata='[{"WordLinkAlias":"wordlinkReplace4","WordLinkUrl":"http://chabaoo.cn","WordLinkName":"你大爺21"},{"WordLinkAlias":"wordlinkReplace7","WordLinkUrl":"http://sc.jb51.net","WordLinkName":"電腦"}]'
wordlinkdata變量存放一些json數(shù)據(jù),這些數(shù)據(jù)是第二步的操作生成的。"WordLinkAlias"指的是關(guān)鍵詞的名稱,"WordLinkUrl"是關(guān)鍵字的鏈接。
在前臺(tái)頁(yè)面引用我們生成的js文件,我工作中使用的是jquery庫(kù)。我們需要做工作是替換文章中所有的關(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擴(kuò)展是一個(gè)高亮擴(kuò)展,我修改了一下,用來(lái)滿足需求,如果你需要修改鏈接的樣式,或者想自己創(chuàng)建別的元素,你可以修改以下的代碼
var spannode = document.createElement('a');
spannode.className = 'divArtContentAlink';
spannode.href = url;
spannode.target = 'blank';
不過(guò)這個(gè)方法的缺陷是,當(dāng)關(guān)鍵字過(guò)多的時(shí)候(超過(guò)150個(gè)),頁(yè)面的速度會(huì)下降
總結(jié):這種方式的優(yōu)勢(shì)是,不需要對(duì)以前的文章做任何的修改,添加,刪除,修改很靈活
缺點(diǎn)是:一旦關(guān)鍵字太多,速度會(huì)下降。
大家如果遇到過(guò)這種情況,可以探討下。期待更好的解決方案
- 用JS讓文章內(nèi)容指定的關(guān)鍵字加亮
- 一個(gè)對(duì)于js this關(guān)鍵字的問(wèn)題
- Jquery 高亮顯示文本中重要的關(guān)鍵字
- jquery 關(guān)鍵字“拖曳搜索”之“拖曳”以及 圖片“提示自適應(yīng)放大”效果 的實(shí)現(xiàn)
- jquery 結(jié)合C#后臺(tái)的數(shù)組對(duì)文章的關(guān)鍵字自動(dòng)添加鏈接的代碼
- JQuery+JS實(shí)現(xiàn)仿百度搜索結(jié)果中關(guān)鍵字變色效果
- 仿百度的關(guān)鍵詞匹配搜索示例
- JS實(shí)現(xiàn)關(guān)鍵字搜索時(shí)的相關(guān)下拉字段效果
- Python抓取淘寶下拉框關(guān)鍵詞的方法
- jQuery過(guò)濾HTML標(biāo)簽并高亮顯示關(guān)鍵字的方法
- 基于jQuery實(shí)現(xiàn)搜索關(guān)鍵字自動(dòng)匹配功能
相關(guān)文章
jQuery完成表單驗(yàn)證的實(shí)例代碼(純代碼)
這篇文章主要介紹了jquery完成表單驗(yàn)證的實(shí)例代碼,代碼簡(jiǎn)單易懂,需要的朋友可以參考下2017-09-09使用jquery實(shí)現(xiàn)仿百度自動(dòng)補(bǔ)全特效
這里給大家分享的效果是像百度的搜索框一樣,當(dāng)用戶在文本框輸入前幾個(gè)字母或是漢字的時(shí)候,該控件就能從存放數(shù)據(jù)的文或是數(shù)據(jù)庫(kù)里將所有以這些字母開(kāi)頭的數(shù)據(jù)提示給用戶,供用戶選擇,提供方便,增加用戶體驗(yàn)。2015-07-07jQuery的3種請(qǐng)求方式$.post,$.get,$.getJSON
這篇文章主要介紹了jQuery的3種請(qǐng)求方式$.post,$.get,$.getJSON,需要的朋友可以參考下2014-03-03EasyUI中datagrid在ie下reload失敗解決方案
這篇文章主要介紹了EasyUI中datagrid在ie下reload失敗解決方案,結(jié)合網(wǎng)上搜集來(lái)的幾種方案,最終解決了這個(gè)問(wèn)題,分享給大家,希望對(duì)大家能夠有所幫助。2015-03-03Bootstrap中點(diǎn)擊按鈕后變灰并顯示加載中實(shí)例代碼
Bootstrap插件非常的好用了,今天小編通過(guò)本教程給大家介紹Bootstrap中點(diǎn)擊按鈕后變灰并顯示加載中實(shí)例代碼,非常不錯(cuò),感興趣的朋友一起看看吧2016-09-09JQuery一種取同級(jí)值的方式(比如你在GridView中)
JQuery一種取同級(jí)值的方式 比如你在GridView中,實(shí)現(xiàn)代碼如下,需要的朋友可以參考下2012-03-03PHP+MySQL+jQuery隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置實(shí)例講解
這篇文章主要介紹了PHP+MySQL+jQuery隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置的實(shí)現(xiàn)方法,感興趣的小伙伴們可以參考一下2015-10-10jQuery插件easyUI實(shí)現(xiàn)通過(guò)JS顯示Dialog的方法
這篇文章主要介紹了jQuery插件easyUI實(shí)現(xiàn)通過(guò)JS顯示Dialog的方法,實(shí)例分析了jQuery插件easyUI彈出Dialog的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-09-09