UBB代碼對于經(jīng)常上論壇的朋友來說是最熟悉不過了。經(jīng)典論壇的UBB轉(zhuǎn)換我覺得是處理的非常好的,研究了一下它的轉(zhuǎn)換結(jié)果[因為沒有源碼:)],做了下面的演示。轉(zhuǎn)換結(jié)果基本上覺得象了。
主要是針對[code][html]這兩個標簽的處理,其他的UBB標簽還是一般的處理方法。
下面是分別用javascript和vbscript實現(xiàn)的演示。自己做論壇的朋友,假如想實現(xiàn)類似經(jīng)典論壇的運行代碼框可以看看這種轉(zhuǎn)換。
歡迎大家輸入盡量多格式的UBB進行測試,多多指出錯誤。
javascript:
<style>.CodeSamp { PADDING-RIGHT: 0.5em; MARGIN-TOP: 1em; PADDING-LEFT: 0.5em; FONT-SIZE: 8p; MARGIN-BOTTOM: 1em; PADDING-BOTTOM: 0.5em; MARGIN-LEFT: 0pt; PADDING-TOP: 0.5em; FONT-FAMILY: "Courier New"; BACKGROUND-COLOR: #eeeeee;width: 480px;overflow:hidden;border: 1px solid #888888;}textarea {border-width: 1; border-color: #000000;font-size: 12px;FONT-FAMILY: "Tahoma", "MS Shell Dlg";}</style>
<TEXTAREA name=phx cols=65 rows=12>[i][b][color=blue]blue[/color][/b][/i]
[html][color=red]test[/color][/html]
[html][code]test[/code][/html]
[code][html]test[/html][/code]</textarea><br><button onclick=show.innerHTML=UBBCode(phx.value,"html")>轉(zhuǎn)換</button><br><div id=show style="border:1 solid skyblue;width=500;font-size: 12px;FONT-FAMILY: 'Tahoma', 'MS Shell Dlg';"></div>
<script>strIcons = "1" //答應笑臉轉(zhuǎn)換strSmile="1" //同上ImgName="em"picurl="pic/"
function UBBCode(content,html){st=new Date().getTime()content=content.replace(/\[(\/)?phx_code\]/ig,"{$1phx_code}");content=content.replace(/\[(\/)?phx_html\]/ig,"{$1phx_html}");content="[phx_code]" content "[/phx_code]"; content=content.replace(/(\[code\]([\s\S] ?)\[\/code\])/ig,"[/phx_code]$1[phx_code]");content=content.replace(/\[phx_code\]([\s\S]*?)\[\/phx_code\]/ig,function($1,$2){if(html=="html"){return(HTMLCode($2));}else{return(trans($2));}});content=content.replace(/\[code\](\r\n)?([\s\S] ?)\[\/code\]/ig,function($1,$2,$3){return("<PRE class=CodeSamp>" DvbbsHtmlAn($3) "</PRE>")});content=content.replace(/\{(\/)?phx_code\}/ig,"[$1phx_code]");content=content.replace(/\{(\/)?phx_html\}/ig,"[$1phx_html]");alert('共耗時 ' eval(new Date().getTime()-st) ' ms');return(content);}
function HTMLCode(content){ content="[phx_html]" content "[/phx_html]"; content=content.replace(/(\[html\]([\s\S] ?)\[\/html\])/ig,"[/phx_html]$1[phx_html]");content=content.replace(/\[phx_html\]([\s\S]*?)\[\/phx_html\]/ig,function($1,$2){return(trans($2))});content=content.replace(/\[html\]([\s\S] ?)\[\/html\]/ig,function($1,$2){return("<span><TEXTAREA cols=95 rows=12>" hencode($2) "</TEXTAREA><br><INPUT onclick=runCode() type=button value=運行代碼>[Ctrl A 全部選擇 提示:你可先修改部分代碼,再按運行]</span>")});return(content);
復制本頁鏈接| 搜索UBB 轉(zhuǎn)換函數(shù)演示
Dreamweaver教程-UBB 轉(zhuǎn)換函數(shù)演示。