本日志标题:如何才能让搜索出来的关键字变红色?        [2004-9-4]

在BI的一份帖子中小荷的回帖,已经做成了函数。

输入内容:cnbruce love cnrose

输入查询内容: cn

你会发现结果的。


[Ctrl+A 全部选择进行拷贝 提示:可先修改部分代码,再点击运行]


再来一个正则匹配的


[Ctrl+A 全部选择进行拷贝 提示:可先修改部分代码,再点击运行]



<%
' 以前写全文检索程序的时候写的.
' 原创 by 飞鸟@dev-club.com
' Email: flybird@dev-club.com
' ie5.5 脚本引擎 required

  dim patern
  dim found
  
  dim str
  dim result
  
  patern="(a)|(b)"
  str=" A dog fall in love with a cat. Can you believe?"
  result=""  
  call getMatchText(str,result,false)
  Response.Write result

  sub getMatchText(byref str,byref result,isNeedTrunc)
    'on error resume next
    Dim regEx, Match, Matches
    dim tStr
    Set regEx = New RegExp     ' 建立正则表达式。    
    regEx.Pattern = (patern)  ' 设置模式。
    regEx.IgnoreCase = True     ' 设置是否区分字符大小写。
    regEx.Global = True     ' 设置全局可用性。
    Set Matches = regEx.Execute(str)  ' 执行搜索。  
    if err.number<>0 then
      response.write "错误1:" & err.description
      err.clear
      exit sub
    end if
    if matches.count <>0 then
      dim startIndex      
      dim myMatchValue
      startIndex=1
      for each match in matches
        if (instr(str,match.value)>0) then
          if instr(str,match.value)-50 >0 then
            startIndex=instr(str,match.value)-50
          else
            startIndex=1
          end if
          myMatchValue=match.value
          exit for
        end if
      next
      if isNeedTrunc then
        result= (mid(str,startIndex,strLength(myMatchValue)+100))
      else
        result= (str)  
      end if
      for each match in matches
        if not(instr(result,"<font color=red>" & match.value & "</font>")>0) then
          result=replace(result,match.value,"<font color=red>" & match.value & "</font>" )
        end if
      next
      found=true
    else
      found=false
    end if  
    set regEx=nothing
  end sub  
%>



[Edit on 2004-12-6 1:24:41 By cnbruce]

在百度搜索完整的如何才能让搜索出来的关键字变红色?内容,或者用Google搜索相关的更多内容

By [cnbruce] at 22:32:59 | 评论 [38] | 浏览 [18875] | TrackBack| 返回顶部

About Comments
不对吧.
输入:aaabacsels sks
查询:a
你看看结果
By [yyy] at 2004-9-7 11:22:21
是哦,
aaaaaaaaaaaaaaa
搜索a
好像是间隔的,
By [cnbruce] at 2004-9-7 11:38:11
Dim nPos
Dim nLen
Dim nLenAll

nLen = Len(strFind)
nLenAll = nLen + Len(strBefore) + Len(strAfter) + 1

===============================

把那个加1去掉不就可以咯

Dim nPos
Dim nLen
Dim nLenAll

nLen = Len(strFind)
nLenAll = nLen + Len(strBefore) + Len(strAfter)



By [amily] at 2004-9-8 4:21:05
不对哦~
By [成绩是汗] at 2004-9-14 16:24:16
是不有些浏览器不支持呀?
By [萝卜菜] at 2012-10-11 16:52:35
cvbxcv
By [mkkkk] at 2012-12-3 11:39:55


Post a Comment
呢称: 验证码: 
禁止笑脸转换 禁止UBB | 缩放输入框:6 5 | [Ctrl+Enter提交](1000个字符限制)