当前位置: 首页 > 图文教程 > 网络编程 > Javascript > JScript5.5下String.prototype.replace(str,func)的UBB嵌套的递归解开。

Javascript
通过JavaScript脚本复制网页上的一个表格
光标定位等TextRange的操作的范例代码
网页与键盘
下拉菜单
点此处秒后立即下载
繁简字转换功能
用javascript制作放大镜放大图片
一个非常强大完整的web表单验证程序Validator v1.05
[原创]checkbox实现全选的多种方法 不断更新
关于IFRAME 自适应高度的研究
document.all还是document.getElementsByName?
光标的帖子总结(Range的使用)
下拉菜单既可以选择,又可以自己填写
用于table内容排序
匹配html标记的正则
图片向上滚动
常用参考资料(手册)下载或者链接
測試代碼真方便
CSS+JS构建的图片查看器
如何实现iframe(嵌入式帧)的自适应高度

Javascript 中的 JScript5.5下String.prototype.replace(str,func)的UBB嵌套的递归解开。


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-10   浏览: 162 ::
收藏到网摘: n/a

看这个例子:

一般的UBB很难解决UBB元素"[xx]"的嵌套包含的。

使用JScript5.5的新特征,完全解决了这个问题了。

前提是UBB文本写法中,嵌套要正规,不然会影响的是嵌套内部的解析。

 

var thestr="a1[b]a2[b]centerb2[/b]b1[/b]";
function NormalUBB(str)
{
 if(typeof(str)!="string")str=str+"";
 str=str.replace(/(\[b\])(.*)(\[\/b\])/gi,"<b>$2</b>");
 return str;
}
function LostinetUBB(str)
{
 if(typeof(str)!="string")str=str+"";
 str=str.replace(
  /(\[b\])(.*)(\[\/b\])/gi,
  function(str,pos,raw)
  {
   return LostinetUBB(
   str.replace(/(\[b\])(.*)(\[\/b\])/gi,"<b>$2</b>")
   );
  }
 );
 return str;
}
alert(NormalUBB(thestr));
alert(LostinetUBB(thestr));