dis*_*cer 77 javascript regex repeat capturing-group
我希望这行JavaScript:
"foo bar baz".match(/^(\s*\w+)+$/)
返回类似的东西:
["foo bar baz", "foo", " bar", " baz"]
但它只返回最后捕获的匹配:
["foo bar baz", " baz"]
有没有办法获得所有捕获的匹配?
pol*_*nts 85
重复捕获组时,在大多数情况下,只保留最后一次捕获; 以前的任何捕获都会被覆盖.在某些风格中,例如.NET,您可以获得所有中间捕获,但Javascript不是这种情况.
也就是说,在Javascript中,如果你有一个带有N个捕获组的模式,你只能捕获每个匹配的N个字符串,即使其中一些组被重复.
所以一般来说,取决于你需要做什么:
/(pattern)+/,也许/pattern/g是在一个exec循环中
 匹配这是一个<some;words;here>在文本中匹配,使用exec循环,然后拆分;以获取单个单词的示例(另请参见ideone.com):
var text = "a;b;<c;d;e;f>;g;h;i;<no no no>;j;k;<xx;yy;zz>";
var r = /<(\w+(;\w+)*)>/g;
var match;
while ((match = r.exec(text)) != null) {
  print(match[1].split(";"));
}
// c,d,e,f
// xx,yy,zz
使用的模式是:
      _2__
     /    \
<(\w+(;\w+)*)>
 \__________/
      1
这符合<word>,<word;another>,<word;another;please>,等2组重复捕捉到任何数量的话,但它只能保存最近捕获.整个单词列表由第1组捕获; 然后这个字符串split在分号分隔符上.
除非您对如何拆分字符串有更复杂的要求,否则可以拆分它们,然后使用它们返回初始字符串:
var data = "foo bar baz";
var pieces = data.split(' ');
pieces.unshift(data);
| 归档时间: | 
 | 
| 查看次数: | 39362 次 | 
| 最近记录: |