ubb代码的简单实现

发表于:2007-06-30来源:作者:点击数: 标签:
关于UBB的详细情况,请点这个链接 http://www.chinaasp.com/sqlbbs/help/aboutUBB.asp 查看。 UBB的实现原理无外乎字符串的查找和替换。因此Microosft Script Engine 5.0版本的RegExp(正则表达式对象)是个不错的选择,但我想由于ISP的关系,我现在这个网站(信
关于UBB的详细情况,请点这个链接 http://www.chinaasp.com/sqlbbs/help/aboutUBB.asp 查看。
UBB的实现原理无外乎字符串的查找和替换。因此Microosft Script Engine 5.0版本的RegExp(正则表达式对象)是个不错的选择,但我想由于ISP的关系,我现在这个网站(信诺立)就还不支持Microsoft Script Engine 5.0。所以下面这个子程序可能更适合大家一些。
□Convert-实现ubb标记的查找和替换,当前实现了b/url/url1(在一个新窗口中打开链接)/#/hr等多个标记,大家可以自己增加其他标记。
□调用方法
if convert(text,"url")=false then
    ‘’url标记错误处理
end if
□convert函数代码
Function Convert(ByRef intext, UBB)
    ‘’变量定义
    Dim intStart
    Dim intStartPostion
    Dim intEndPostion
    Dim strStartUBB
    Dim strEndUBB
    Dim intStartUBBLen
    Dim intEndUBBLen
    Dim intStrLen
    intStrLen = Len(intext)
    Dim strContent
    Dim strFinish
    ‘’彩色标记
    Dim strColor
    ‘’#号ubb开始标记的结束]位置
    Dim intJHEndPostion
    intStart = 1
    If UBB = "#" Then
        strStartUBB = "[" & "#"
    Else
        strStartUBB = "][" & UBB & "]"
    End If
    If UBB = "hr" Then
        intStartPostion = InStr(intStart, intext, strStartUBB, 1)
        do until intStartPostion=0
            intext = Replace(intext, strStartUBB, "<hr size=1>", 1, -1, 1)
            intStart=intStartPostion+len(strStartUBB)
            intStartPostion = InStr(intStart, intext,strStartUBB, 1)

        Loop
        convert=true
        exit function
    End If
    
    strEndUBB = "[/" & UBB & "]"
    intStartUBBLen = Len(strStartUBB)
    intEndUBBLen = Len(strEndUBB)
    
    intStartPostion = InStr(intStart, intext, strStartUBB, 1)
    Do Until intStartPostion = 0
        ‘’找匹配UBB
        intEndPostion = InStr(intStart, intext, strEndUBB, 1)
        If intEndPostion = 0 Then
            Convert = False
            Exit Function
        Else
            ‘’取中间字符串
            If UBB = "#" Then
                ‘’#号特殊处理
                intJHEndPostion = InStr(intStartPostion, intext, "]")
                If intJHEndPostion = 0 Then
                    Convert = False
                    Exit Function
                End If
                strColor = Mid(intext, intStartPostion + intStartUBBLen, intJHEndPostion - intStartPostion - intStartUBBLen)
                strContent = Mid(intext, intStartPostion + intStartUBBLen + Len(strColor) + 1, intEndPostion - intStartPostion - intStartUBBLen - Len(strColor) - 1)
            Else
                strContent = Mid(intext, intStartPostion + intStartUBBLen, (intEndPostion - intStartPostion - intStartUBBLen))
            End If
            ‘’UBB处理
            Select Case Ucase(UBB)
            ‘’黑体
            Case "B"
                strFinish = "<b>" & strContent & "</b>"
            Case "URL"
                strFinish = "<a href=" & strContent & ">" & strContent & "</a>"
            ‘’你可以增加其他标记
            Case "URL1"
                ‘’在另一个窗口打开
                strFinish = "<a href=" & strContent & " target=_blank>" & strContent & "</a>"
            Case "IMG"
                strFinish = "<img src=" & strContent & ">"
            Case "#"
                strFinish = "<font color=#" & strColor & ">" & strContent & "</font>"
            End Select
            ‘’替换
            If UBB = "#" Then
                intext = Replace(intext, strStartUBB & strColor & "]" & strContent & strEndUBB, strFinish, 1, -1, 1)
            Else
                intext = Replace(intext, strStartUBB & strContent & strEndUBB, strFinish, 1, -1, 1)
            End If
        End If
        intStart = intStartPostion + 1
        intStartPostion = InStr(intStart, intext, strStartUBB, 1)
    Loop
    Convert = True
End Function

//站长:webmaster@chinaasp.com 注:此段代码不是Chinaasp采用的代码,chinaasp的代码是露茜所作, 

原文转自:http://www.ltesting.net