0

我有以下正则表达式,我试图在其中捕获每个开始评论的 ID。但由于某种原因,我只能捕捉到第一个。它不会抓取嵌套评论的 ID。它只在控制台上打印 1000。我试图让它同时捕获 1000 和 2000。任何人都可以在我的正则表达式中发现错误吗?

<script type="text/javascript">

    function ExtractText() {
        var regex = /\<!--Start([0-9]{4})-->([\s\S]*?)<!--End[0-9]{4}-->/gm;
       var match;
        while (match = regex.exec($("#myHtml").html())) {
            console.log(match[1]);
        }
    }

</script>

<div id="myHtml">
   <!--Start1000-->Text on<!--Start2000-->the left<!--End1000-->Text on the right<!--End2000-->
</div> 

根据 Mike Samuel 的回答,我将 JS 更新为以下内容:

function GetAllIds() {

        var regex = /<!--Start([0-9]{4})-->([\s\S]*?)<!--End\1-->/g;
        var text = $("#myHtml").html();
        var match;
        while (regex.test(text)) {
            text = text.replace(
               regex,
               function (_, id, content) {
                   console.log(id);
                   return content;
               });
        }
    }
4

2 回答 2

2

<!--Start1000-->Text on<!--Start2000-->the left<!--End1000-->Text on the right<!--End2000-->

“1000”区域与“2000”区域重叠,但exec循环只找到不重叠的匹配,因为每次exec使用相同的正则表达式和字符串调用都在最后一个匹配的末尾开始。要解决此问题,请尝试

var regex = /<!--Start([0-9]{4})-->([\s\S]*?)<!--End\1-->/g;
for (var s = $("#myHtml").html(), sWithoutComment;
     // Keep going until we fail to replace a comment bracketed chunk
     // with the chunk minus comments.
     true;
     s = sWithoutComment) {
  // Replace one group of non-overlapping comment pairs.
  sWithoutComment = s.replace(
     regex,
     function (_, id, content) {
       console.log(id);
       // Replace the whole thing with the body.
       return content;
     });
  if (s === sWithoutComment) { break; }
}
于 2013-03-19T22:31:25.983 回答
1

您可以使用分组,然后使用另一个正则表达式:

var regex =  /(<!--Start)([0-9]{4})/ig;
var str = document.getElementById('myHtml').innerHTML;
var matches = str.match(regex);
for(var i=0;i<matches.length;i++){
    var m = matches[i];
    var num = m.match(/(\d+)/)[1];
    console.log(num);
}
于 2013-03-19T23:43:33.817 回答