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

Javascript
用Javascript轻松制作抽奖系统
一个鼠标效果,代码简单易懂,效果不错的
JavaScript的目的
时钟显示在任意指定位置
浅谈在网页上显示日期的两种方法
设计干净的链接
动态CSS,换肤技术
说不清的 childNodes
innerHTML和innerText的使用方法
Web开发:Javascript是Web开发正确方向的一个错误吗?
JS特效代码:实现间歇无缝文字滚动特效
Javascript编程语言和DOM接口系列教程(1)
JS实例教程:用6N±1法求素数
Firefox的Jetpack扩展案例分析:Gmail邮件提醒
JS小游戏实例:2D桌面台球
JS实例教程:制作图片放大特效
用Ant构建JavaScript组件
JavaScript组件:编码实现和算法
JS教程:制作颜色梯度和渐变效果
JS编码技巧:翻译的14天JS编写技巧

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-10   浏览: 186 ::
收藏到网摘: 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));