JS批量替換內(nèi)容中關(guān)鍵詞為超鏈接
懂點(diǎn)seo的人都知道要給內(nèi)容中關(guān)鍵詞加上鏈接,形成站內(nèi)錨文本鏈接,這對(duì)seo有很大的幫助。
思路就是在數(shù)據(jù)庫(kù)中錄入若干個(gè)關(guān)鍵詞和關(guān)鍵詞對(duì)應(yīng)的鏈接,當(dāng)然鏈接可以根據(jù)關(guān)鍵詞的id自動(dòng)生成,或者直接用關(guān)鍵詞作為鏈接參數(shù),如?tag=1、?kw=關(guān)鍵詞。
這個(gè)問(wèn)題不是簡(jiǎn)單的一個(gè)批量replace那么簡(jiǎn)單,要考慮到已經(jīng)存在的超鏈接,不能將里面的文字再次替換為超鏈接,還有就是圖片的alt屬性,或者其他標(biāo)簽的title屬性,里面的文字也不該被替換。
見(jiàn)下面的HTML代碼:
【<a rel="external nofollow" rel="external nofollow" >九寨溝概要</a>】九寨溝位于四川省阿壩州九寨溝縣境內(nèi),5A景點(diǎn),世界自然遺產(chǎn),有"五絕"之景色,我感到最絕的是海子,此生不能不去的景區(qū)。一年四季適合游,秋天是最美的。 <img src="" alt="九寨溝圖片" title="九寨溝圖片" />
這種情況你不能直接將九寨溝替換為超鏈接啊,不然第一個(gè)鏈接就會(huì)被替換為鏈接中包含鏈接,然后是圖片上的alt和title也替換了一個(gè)鏈接上去,這肯定是不符合HTML規(guī)范的。
情景一:排除屬性中的關(guān)鍵詞
匹配的正則為:關(guān)鍵詞[^<]*>,所以排除這個(gè)關(guān)鍵詞的正則為:關(guān)鍵詞?!([^<]*>)。
情景二:排除鏈接中的關(guān)鍵詞
匹配的正則為:關(guān)鍵詞[^<]*<\/a>,所以排除這個(gè)關(guān)鍵詞的正則為:關(guān)鍵詞?!([^<]*<\/a>)。
整合兩種情況的結(jié)果為:var reg=/關(guān)鍵詞(?!([^<]*>)|([^<]*<\/a>))/ig;
廢話(huà)不多說(shuō),最后給出一個(gè)完整的批量替換實(shí)例:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無(wú)標(biāo)題文檔</title>
</head>
<body>
<div id="content">
【<a rel="external nofollow" rel="external nofollow" >九寨溝概要</a>】九寨溝位于四川省阿壩州九寨溝縣境內(nèi),5A景點(diǎn),世界自然遺產(chǎn),有"五絕"之景色,我感到最絕的是海子,此生不能不去的景區(qū)。一年四季適合游,秋天是最美的。
<img src="" alt="九寨溝圖片" title="九寨溝圖片" />
</div>
<hr />
<div id="new">
</div>
<script>
var c=document.getElementById("content").innerHTML;
//var reg=/九寨溝(?!([^<]*>)|([^<]*<\/a>))/ig;
var json=[
{'key':'九寨溝','url':'/九寨溝/'}
,{'key':'景點(diǎn)','url':'/景點(diǎn)/'}
,{'key':'景區(qū)','url':'/景區(qū)/'}
];
var reg;
for(var i=0;i<json.length;i++){
var j=json[i];
reg=new RegExp(j.key+"(?!([^<]*>)|([^<]*<\/a>))","ig");
c = c.replace(reg,"<a href='"+j.url+"'>"+j.key+"</a>");
}
document.getElementById("new").innerHTML=c;
</script>
</body>
</html>
替換后的效果:

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
- Node.js讀寫(xiě)文件之批量替換圖片的實(shí)現(xiàn)方法
- js replace(a,b)之替換字符串中所有指定字符的方法
- JS實(shí)現(xiàn)添加,替換,刪除節(jié)點(diǎn)元素的方法
- js正則表達(dá)式replace替換變量方法
- javascript字符串替換函數(shù)如何一次性全部替換掉
- js中字符替換函數(shù)String.replace()使用技巧
- javascript中使用replaceAll()函數(shù)實(shí)現(xiàn)字符替換的方法
- js使用正則實(shí)現(xiàn)ReplaceAll全部替換的方法
- 用JS實(shí)現(xiàn)HTML標(biāo)簽替換效果
- JS替換字符串中字符即替換全部而不是第一個(gè)
相關(guān)文章
Js判斷兩個(gè)數(shù)組是否相等的幾種常見(jiàn)場(chǎng)景
無(wú)論是在開(kāi)發(fā)中還是面試時(shí),在js中判斷變量是否相等,都是一個(gè)比較常見(jiàn)的問(wèn)題,這篇文章主要給大家介紹了關(guān)于Js判斷兩個(gè)數(shù)組是否相等的幾種常見(jiàn)場(chǎng)景,需要的朋友可以參考下2024-07-07
JavaScript幾種形式的樹(shù)結(jié)構(gòu)菜單
今天我主要講3種不同展示的JavaScript樹(shù)結(jié)構(gòu)菜單,分別是懸浮層樹(shù)(Tree)、右鍵菜單樹(shù)(ContextMenu)和節(jié)點(diǎn)樹(shù)(TreeMenu),目前都支持無(wú)限級(jí)層次。2010-05-05
微信小程序?qū)崿F(xiàn)驗(yàn)證碼倒計(jì)時(shí)效果
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)驗(yàn)證碼倒計(jì)時(shí)效果,手機(jī)登錄、填手機(jī)號(hào)獲取驗(yàn)證碼,倒計(jì)時(shí)后重新獲取效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
30分鐘快速實(shí)現(xiàn)小程序語(yǔ)音識(shí)別功能
最近需要在小程序上實(shí)現(xiàn)語(yǔ)音識(shí)別,將需要用到的功能都總結(jié)下,供大家參考。語(yǔ)音識(shí)別用的是科大訊飛,文中給出了詳細(xì)的實(shí)現(xiàn)方法介紹,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
js Array對(duì)象的擴(kuò)展函數(shù)代碼
有時(shí)候我們需要對(duì)js的array對(duì)象擴(kuò)展一些功能,這里簡(jiǎn)單介紹下,方便需要的朋友2013-04-04
layui實(shí)現(xiàn)圖片虛擬路徑上傳,預(yù)覽和刪除的例子
今天小編就為大家分享一篇layui實(shí)現(xiàn)圖片虛擬路徑上傳,預(yù)覽和刪除的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09

