高亮显示不区分大小写的关键字——ASP

简介:   今日,碰到一个问题:如何在网页中高亮显示不区分大小写的关键字   例如:文本abcaBcabCaBCabcaBCa,关键字bc,在不区分大小写的情况,一共有6个匹配项。   则在网页中显示的是abcaBcabCaBCabcaBCa。

  今日,碰到一个问题:如何在网页中高亮显示不区分大小写的关键字

  例如:文本abcaBcabCaBCabcaBCa,关键字bc,在不区分大小写的情况,一共有6个匹配项。

  则在网页中显示的是abcaBcabCaBCabcaBCa。

  很多人,想到是replace函数。原型为

    Replace(string,find,replacewith[,start[,count[,compare]]])

    string    必选项,字符串表达式,包含要替代的子字符串

    find     必选项,被搜索的子字符串

    replacewith 必选项,用于替换的子字符串

    start    可选项,开始搜索子字符串的位置,默认是1

    count    可选项,执行子字符串替换的数目,默认是-1,表示进行所有可能的替换

    compare  可选项,比较方式,0:二进制比较;1:文本比较

  

  虽然最后一个参数能解决不区分大小写的问题,那么该替换为什么呢?

  因为从示例上看,bc,Bc,bC,BC都被搜索到了,却不能统一替换为一个文本

  那么,利用Instr这个函数来协助我们吧。

  从源字符串,自左向右搜索,每找到一个匹配项。就按三步走

    1、将匹配项左边的字符串输出

    2、将匹配项套上样式<span>后输出

    3、重复上两步,继续搜索右边的字符串,直到搜索结尾

 

  代码如下:

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

 

  调用的时候,代码如下:

  

tS = " abcaBcabCaBCabcaBCa "
tF
= " bc "
response.Write(tS)
response.Write(
" <br/> " )
response.Write(HighLight(tS,tF))

 

  这样就实现了如开头实例的样子

  另一方面,思考是否用正则表达式更方便呢?尝试了几次,没有结果。看看哪位高手用正则来解决这个问题。

 

  写了文章以后,网友“愚公”给出了正则表达式的解法。经测试,正确无误。现将他的代码贴于后。非常感谢他。

  

img_405b18b4b6584ae338e0f6ecaf736533.gif 代码
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 " )

 

 

相关文章
|
Web App开发 前端开发 JavaScript
前端必备技能---今天教会你如何高效使用Chrome调试与检测你的CSS代码
教会你如何高效使用Chrome调试与检测你的CSS代码
651 0
前端必备技能---今天教会你如何高效使用Chrome调试与检测你的CSS代码
|
安全 Java 测试技术
软考详细备考攻略
软考详细备考攻略
1198 0
软考详细备考攻略
|
13天前
|
存储 弹性计算 人工智能
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
2025年9月24日,阿里云弹性计算团队多位产品、技术专家及服务器团队技术专家共同在【2025云栖大会】现场带来了《通用计算产品发布与行业实践》的专场论坛,本论坛聚焦弹性计算多款通用算力产品发布。同时,ECS云服务器安全能力、资源售卖模式、计算AI助手等用户体验关键环节也宣布升级,让用云更简单、更智能。海尔三翼鸟云服务负责人刘建锋先生作为特邀嘉宾,莅临现场分享了关于阿里云ECS g9i推动AIoT平台的场景落地实践。
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
|
5天前
|
云安全 人工智能 安全
Dify平台集成阿里云AI安全护栏,构建AI Runtime安全防线
阿里云 AI 安全护栏加入Dify平台,打造可信赖的 AI
|
12天前
|
人工智能 自然语言处理 自动驾驶
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
|
8天前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
768 23
|
7天前
|
人工智能 Java Nacos
基于 Spring AI Alibaba + Nacos 的分布式 Multi-Agent 构建指南
本文将针对 Spring AI Alibaba + Nacos 的分布式多智能体构建方案展开介绍,同时结合 Demo 说明快速开发方法与实际效果。
495 37