ASP 高亮顯示不區(qū)分大小寫(xiě)的關(guān)鍵字
則在網(wǎng)頁(yè)中顯示的是abcaBcabCaBCabcaBCa。
很多人,想到是replace函數(shù)。原型為
Replace(string,find,replacewith[,start[,count[,compare]]])
string 必選項(xiàng),字符串表達(dá)式,包含要替代的子字符串
find 必選項(xiàng),被搜索的子字符串
replacewith 必選項(xiàng),用于替換的子字符串
start 可選項(xiàng),開(kāi)始搜索子字符串的位置,默認(rèn)是1
count 可選項(xiàng),執(zhí)行子字符串替換的數(shù)目,默認(rèn)是-1,表示進(jìn)行所有可能的替換
compare 可選項(xiàng),比較方式,0:二進(jìn)制比較;1:文本比較
雖然最后一個(gè)參數(shù)能解決不區(qū)分大小寫(xiě)的問(wèn)題,那么該替換為什么呢?
因?yàn)閺氖纠峡矗琤c,Bc,bC,BC都被搜索到了,卻不能統(tǒng)一替換為一個(gè)文本
那么,利用Instr這個(gè)函數(shù)來(lái)協(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)了如開(kāi)頭實(shí)例的樣子
另一方面,思考是否用正則表達(dá)式更方便呢?嘗試了幾次,沒(méi)有結(jié)果??纯茨奈桓呤钟谜齽t來(lái)解決這個(gè)問(wèn)題。
寫(xiě)了文章以后,網(wǎng)友“愚公”給出了正則表達(dá)式的解法。經(jīng)測(cè)試,正確無(wú)誤?,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")
相關(guān)文章
asp執(zhí)行帶參數(shù)的sql語(yǔ)句實(shí)例
這篇文章主要介紹了asp執(zhí)行帶參數(shù)的sql語(yǔ)句實(shí)例,參數(shù)化SQL語(yǔ)句可以有效的防止SQL注入漏洞,需要的朋友可以參考下2014-08-08Js獲取asp頁(yè)面返回的值(加載值)實(shí)現(xiàn)代碼
本文詳細(xì)介紹Js獲取asp頁(yè)面返回的值(加載值)實(shí)現(xiàn)方法,需要了解的朋友可以參考下2012-12-12asp中設(shè)置session過(guò)期時(shí)間方法總結(jié)
asp中默認(rèn)session過(guò)期時(shí)間為20分鐘,很多情況下不夠,今天有客戶(hù)要求很多就要重新登錄了,所以準(zhǔn)備了這篇文章,方便需要的朋友2012-09-09asp 讀取通過(guò)表單發(fā)送的post數(shù)據(jù)
學(xué)習(xí)ASP,最重要的就是要掌握ASP內(nèi)置的六大對(duì)象,如果以前沒(méi)接觸過(guò),聰明的您就不要管這些概念了,知道怎么用就行了,我的觀點(diǎn)是剛開(kāi)始關(guān)鍵在于臨摹2012-12-12discuz 2.0整合asp系統(tǒng),用戶(hù)添加函數(shù)
我的做法是,用戶(hù)在原來(lái)的登錄系統(tǒng)登錄一次,記錄用戶(hù)名和密碼明碼,然后往數(shù)據(jù)庫(kù)里面添加一個(gè)論壇用戶(hù)(注意密碼用32位的MD5),然后再用雪人的方法整合同步登錄就可以了2009-06-06flash和asp分頁(yè)的一點(diǎn)心得與flash腳本
flash和asp分頁(yè)的一點(diǎn)心得與flash腳本...2007-03-03多域名綁定到一個(gè)空間訪問(wèn)不同首頁(yè)的技巧
多域名綁定到一個(gè)空間訪問(wèn)不同首頁(yè)的技巧...2006-09-09迅雷API接口_通過(guò)腳本調(diào)用迅雷自動(dòng)下載資源
最近在寫(xiě)一個(gè)采集程序,需要下載目標(biāo)站的附件,不過(guò)目標(biāo)站文件下載速度很慢,于是想到能否調(diào)用迅雷來(lái)下載2008-07-07隨機(jī)提取Access/SqlServer數(shù)據(jù)庫(kù)中的10條記錄的SQL語(yǔ)句
隨機(jī)提取Access/SqlServer數(shù)據(jù)庫(kù)中的10條記錄的SQL語(yǔ)句...2006-07-07