首页前端开发其他前端知识巧解 JavaScript 中的嵌套替换(强大正则)

巧解 JavaScript 中的嵌套替换(强大正则)

时间2024-02-01 17:50:03发布访客分类其他前端知识浏览903
导读:收集整理的这篇文章主要介绍了巧解 JavaScript 中的嵌套替换(强大正则 ,觉得挺不错的,现在分享给大家,也给大家做个参考。 网友wys提问:如何仅使用JavaScript支持的正...
收集整理的这篇文章主要介绍了巧解 JavaScript 中的嵌套替换(强大正则),觉得挺不错的,现在分享给大家,也给大家做个参考。 网友wys提问:如何仅使用JavaScript支持的正则语法,将

复制代码 代码如下:
p>
table> p> p> /table>
table> p> p> /table>
p>

中table> .../table> 之间的p> 都替换为br/> ?
思考
该问题的难点之一在于JavaScript支持的正则特性实在有限。楼主已经想到了非JavaScript的解法,如下:
复制代码 代码如下:
re=/(?=table.*?)(p> )(?=.*?\/table> )/gi;
alert (sourcestr.replace(re,"br> "));

嗯,思路大致是这样。较真起来,即使JavaScript支持逆序环视,上面答案并不能够如愿运行。原因是带有量词的逆序环视(即在(?=)里面使用?, *, +, { } 这样的量词)是更高级的的语法,极少有语言能够支持(特例是.Net)。

但是,像楼主这样的正则问题应该是很普便的一个问题,我们经常需要循环地替换一些内容。该如何解答呢?

思路一

阅读JavaScript的文档,我找到了lastIndex这样的东东。根据这个东东,我形成了这样的思路:
•先按外层循环,找到第一组较大的匹配。正则代码是table[^> ]*> [\s\S]*?\/table>
•定位到这次匹配结束的起始位置,替换掉这一段字串中所有的p> 。
•循环执行。
我觉得上述思路大致清晰,但是细节太多(每次匹配涉及3个位置点,一个长度),解起来并非从容不迫,最终的代码想必也不会赏心悦目;尤为重要的是,整个思路像是原始的 Crack,而不是高手的 Hack 。而且思路与正则关系不大。我决定换一条路。

思路二

关键是循环和嵌套。还好不是盗梦空间的深层递归。能否将匹配的内容保护起来,替换完之后再放回原位呢?

想到这里,就豁然开朗了。

思路:先找到所有的匹配内容,记路在数组inner中;

同时使用该正则,将原字串splIT为另一个数组wrapPEr;

一个重要的特点是,wrapper一定比inner多一个元素,它一一将inner项隔开,并处于最外层。wrapper 和 inner 的关系,就像是一个手掌的5根指头与4个指缝的关系。将中间的元素取出,记下位置,等处理完之后,再将所有的元素粘合在一起。就是这样简单。代码如下(为了让问题更有普使性,我稍改了一下源字串):

复制代码 代码如下:
script type="text/javascript">
VAR str="p> table> p> ,p> /table> p> table> p> p> /table> p> table> p> p> /table> ";

var patt=/table[^> ]*> [\s\S]*?\/table> /i;
var wrapper_result=str.split(patt);
var inner_result = str.match(/table[^> ]*> [\s\S]*?\/table> /ig);

var len=inner_result.length;
var final=wrapper_result[0];

for (i=0; ilen; i++)
{
tmp=inner_result[i].replace(/p> /gi,"br> ");
final+=tmp+wrapper_result[i+1];
}
alert(final);
/script>

贴图:


更新

果然是能人辈出,评论更精彩!请看评论中的这则代码:
复制代码 代码如下: alert(sourcestr.replace(/table.*?\/table> /ig, function($1){ return $1.replace(/p> /ig,"br> ")} ));
PS: 本站刚刚添加了评论中代码的解析,可以贴代码了。格式见评论部分的图例显示。谢谢合作! 您可能感兴趣的文章:
  • JS使用正则表达式实现关键字替换加粗功能示例
  • js正则表达式replace替换变量方法
  • js正则查找match()与替换replace()用法实例
  • js使用正则实现ReplaceAll全部替换的方法
  • JS利用正则配合replace替换指定字符
  • js 替换功能函数,用正则表达式解决,js的全部替换
  • JavaScript replace(rgExp,fn)正则替换的用法
  • JS、replace利用正则表达式替换SQL所有参数为指定格式的数据
  • javascript replace()正则替换实现代码
  • js正则实现的密码框简单制作,还可以替换成自己想用得符号
  • javascript用正则表达式把1234567890替换为abcdefghij
  • JS使用正则表达式过滤多个词语并替换为相同长度星号的方法

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 应该如何构造复杂的正则表达式下一篇:python实现统计汉字/英文单词数...猜你在找的正则表达式相关文章 去除内容中的html2022-04-16Python正则表达式保姆式教学详细教程2022-04-16十分钟上手正则表达式 上篇2022-04-16十分钟上手正则表达式 下篇2022-04-16深入浅出正则表达式中的边界\b和\B2022-04-16轻松入门正则表达式之非贪婪匹配篇详解2022-04-16轻松掌握正则表达式findall函数详解2022-04-16正则表达式用法详解2022-04-1636个正则表达式(开发效率提高80%)2022-04-16Python正则表达式指南 推荐2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: 巧解 JavaScript 中的嵌套替换(强大正则)
本文地址: https://pptw.com/jishu/595722.html
Oracle正则表达式使用介绍 js正则表达式之input属性($

游客 回复需填写必要信息