ASP 高亮顯示不區(qū)分大小寫的關(guān)鍵字
更新時(shí)間:2010年01月26日 21:23:33 作者:
今日,碰到一個(gè)問題:如何在網(wǎng)頁中高亮顯示不區(qū)分大小寫的關(guān)鍵字
例如:文本abcaBcabCaBCabcaBCa,關(guān)鍵字bc,在不區(qū)分大小寫的情況,一共有6個(gè)匹配項(xiàng)。
則在網(wǎng)頁中顯示的是abcaBcabCaBCabcaBCa。
很多人,想到是replace函數(shù)。原型為
Replace(string,find,replacewith[,start[,count[,compare]]])
string 必選項(xiàng),字符串表達(dá)式,包含要替代的子字符串
find 必選項(xiàng),被搜索的子字符串
replacewith 必選項(xiàng),用于替換的子字符串
start 可選項(xiàng),開始搜索子字符串的位置,默認(rèn)是1
count 可選項(xiàng),執(zhí)行子字符串替換的數(shù)目,默認(rèn)是-1,表示進(jìn)行所有可能的替換
compare 可選項(xiàng),比較方式,0:二進(jìn)制比較;1:文本比較
雖然最后一個(gè)參數(shù)能解決不區(qū)分大小寫的問題,那么該替換為什么呢?
因?yàn)閺氖纠峡?,bc,Bc,bC,BC都被搜索到了,卻不能統(tǒng)一替換為一個(gè)文本
那么,利用Instr這個(gè)函數(shù)來協(xié)助我們吧。
從源字符串,自左向右搜索,每找到一個(gè)匹配項(xiàng)。就按三步走
1、將匹配項(xiàng)左邊的字符串輸出
2、將匹配項(xiàng)套上樣式<span>后輸出
3、重復(fù)上兩步,繼續(xù)搜索右邊的字符串,直到搜索結(jié)尾
代碼如下:
public function HighLight(S,F)
dim tL,tM,tR,k
tL=""
tM=""
tR=S
k=instr(1,tR,F,1)
do while k>0
tL=tL & left(tR,k-1)
tM=mid(tR,k,len(F))
tL=tL & "<span style='color:red'>" & tM & "</span>"
tR=right(tR,Len(tR)-len(F)-k+1)
k=instr(1,tR,F,1)
loop
HighLight=tL & tR
end function
調(diào)用的時(shí)候,代碼如下:
tS="abcaBcabCaBCabcaBCa"
tF="bc"
response.Write(tS)
response.Write("<br/>")
response.Write(HighLight(tS,tF))
這樣就實(shí)現(xiàn)了如開頭實(shí)例的樣子
另一方面,思考是否用正則表達(dá)式更方便呢?嘗試了幾次,沒有結(jié)果??纯茨奈桓呤钟谜齽t來解決這個(gè)問題。
寫了文章以后,網(wǎng)友“愚公”給出了正則表達(dá)式的解法。經(jīng)測(cè)試,正確無誤?,F(xiàn)將他的代碼貼于后。非常感謝他。
代碼
Function HighLight(S,F)
Dim regEx
Set regEx = New RegExp
regEx.IgnoreCase = True
regEx.Global = True
regEx.Pattern = "(" & F & ")"
HighLight = regEx.Replace(S,"<span style='color:red'>$1</span>")
End Function
Response.write HighLight("abcaBcabCaBCabcaBCa","bc")
則在網(wǎng)頁中顯示的是abcaBcabCaBCabcaBCa。
很多人,想到是replace函數(shù)。原型為
Replace(string,find,replacewith[,start[,count[,compare]]])
string 必選項(xiàng),字符串表達(dá)式,包含要替代的子字符串
find 必選項(xiàng),被搜索的子字符串
replacewith 必選項(xiàng),用于替換的子字符串
start 可選項(xiàng),開始搜索子字符串的位置,默認(rèn)是1
count 可選項(xiàng),執(zhí)行子字符串替換的數(shù)目,默認(rèn)是-1,表示進(jìn)行所有可能的替換
compare 可選項(xiàng),比較方式,0:二進(jìn)制比較;1:文本比較
雖然最后一個(gè)參數(shù)能解決不區(qū)分大小寫的問題,那么該替換為什么呢?
因?yàn)閺氖纠峡?,bc,Bc,bC,BC都被搜索到了,卻不能統(tǒng)一替換為一個(gè)文本
那么,利用Instr這個(gè)函數(shù)來協(xié)助我們吧。
從源字符串,自左向右搜索,每找到一個(gè)匹配項(xiàng)。就按三步走
1、將匹配項(xiàng)左邊的字符串輸出
2、將匹配項(xiàng)套上樣式<span>后輸出
3、重復(fù)上兩步,繼續(xù)搜索右邊的字符串,直到搜索結(jié)尾
代碼如下:
復(fù)制代碼 代碼如下:
public function HighLight(S,F)
dim tL,tM,tR,k
tL=""
tM=""
tR=S
k=instr(1,tR,F,1)
do while k>0
tL=tL & left(tR,k-1)
tM=mid(tR,k,len(F))
tL=tL & "<span style='color:red'>" & tM & "</span>"
tR=right(tR,Len(tR)-len(F)-k+1)
k=instr(1,tR,F,1)
loop
HighLight=tL & tR
end function
調(diào)用的時(shí)候,代碼如下:
復(fù)制代碼 代碼如下:
tS="abcaBcabCaBCabcaBCa"
tF="bc"
response.Write(tS)
response.Write("<br/>")
response.Write(HighLight(tS,tF))
這樣就實(shí)現(xiàn)了如開頭實(shí)例的樣子
另一方面,思考是否用正則表達(dá)式更方便呢?嘗試了幾次,沒有結(jié)果??纯茨奈桓呤钟谜齽t來解決這個(gè)問題。
寫了文章以后,網(wǎng)友“愚公”給出了正則表達(dá)式的解法。經(jīng)測(cè)試,正確無誤?,F(xiàn)將他的代碼貼于后。非常感謝他。
代碼
復(fù)制代碼 代碼如下:
Function HighLight(S,F)
Dim regEx
Set regEx = New RegExp
regEx.IgnoreCase = True
regEx.Global = True
regEx.Pattern = "(" & F & ")"
HighLight = regEx.Replace(S,"<span style='color:red'>$1</span>")
End Function
Response.write HighLight("abcaBcabCaBCabcaBCa","bc")
相關(guān)文章
asp執(zhí)行帶參數(shù)的sql語句實(shí)例
這篇文章主要介紹了asp執(zhí)行帶參數(shù)的sql語句實(shí)例,參數(shù)化SQL語句可以有效的防止SQL注入漏洞,需要的朋友可以參考下2014-08-08Js獲取asp頁面返回的值(加載值)實(shí)現(xiàn)代碼
本文詳細(xì)介紹Js獲取asp頁面返回的值(加載值)實(shí)現(xiàn)方法,需要了解的朋友可以參考下2012-12-12asp中設(shè)置session過期時(shí)間方法總結(jié)
asp中默認(rèn)session過期時(shí)間為20分鐘,很多情況下不夠,今天有客戶要求很多就要重新登錄了,所以準(zhǔn)備了這篇文章,方便需要的朋友2012-09-09asp 讀取通過表單發(fā)送的post數(shù)據(jù)
學(xué)習(xí)ASP,最重要的就是要掌握ASP內(nèi)置的六大對(duì)象,如果以前沒接觸過,聰明的您就不要管這些概念了,知道怎么用就行了,我的觀點(diǎn)是剛開始關(guān)鍵在于臨摹2012-12-12discuz 2.0整合asp系統(tǒng),用戶添加函數(shù)
我的做法是,用戶在原來的登錄系統(tǒng)登錄一次,記錄用戶名和密碼明碼,然后往數(shù)據(jù)庫里面添加一個(gè)論壇用戶(注意密碼用32位的MD5),然后再用雪人的方法整合同步登錄就可以了2009-06-06flash和asp分頁的一點(diǎn)心得與flash腳本
flash和asp分頁的一點(diǎn)心得與flash腳本...2007-03-03迅雷API接口_通過腳本調(diào)用迅雷自動(dòng)下載資源
最近在寫一個(gè)采集程序,需要下載目標(biāo)站的附件,不過目標(biāo)站文件下載速度很慢,于是想到能否調(diào)用迅雷來下載2008-07-07隨機(jī)提取Access/SqlServer數(shù)據(jù)庫中的10條記錄的SQL語句
隨機(jī)提取Access/SqlServer數(shù)據(jù)庫中的10條記錄的SQL語句...2006-07-07