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

Javascript
JavaScript 基础问答一
CSS JavaScript 实现菜单功能 改进版
JavaScript 图片切割效果(放大镜)
JavaScript 拖放效果代码
漂亮的js tab图片轮换效果代码(可自定义的幻灯片和图片缓冲切换)
鼠标滑过 放大显示效果的列表
JS 相册效果 自动播放[本地整合]
仿CSDN 右下角悬挂的浮动层效果
右下角广告(点击广告后出现关闭按钮可关闭)
javascript this用法小结
JavaScript 绘图代码
JavaScript CSS菜单功能 改进版
javascript jQuery插件练习
jQuery 浮动广告实现代码
jQuery 位置插件
jquery 插件之仿“卓越亚马逊”首页弹出菜单效果
jquery 图片预加载 自动等比例缩放插件
JavaScript 仿关机效果的图片层
javascript 对表格的行和列都能加亮显示
JavaScript Select和Option列表元素上下左右移动

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


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