我非常肯定在花了一夜之后试图找到一个不可能的答案,并且我已经开发了一个解决方法 - 但是,如果有人知道更好的方法,我很乐意听到它。 ..
我在代码上经历了很多次迭代,以下只是一个思路。我相信,在某些时候,我正在使用全局标志,以便match()工作,我不记得现在是否有必要。
var str = "@abc@def@ghi&jkl";
var regex = /^(?:@([a-z]+))?(?:&([a-z]+))?$/;
这个简化代码中的想法是可选的组1,其中有一个未指定的数量,将匹配@ abc,@ def和@ghi。它只会捕获将有一个或多个字母字符。第2组是相同的,除了& amp;符号。它也应该锚定在字符串的开头和结尾。
我希望能够支持引用两个组的所有匹配,即:
result = str.match(regex);
alert(result[1]); //abc,def,ghi
alert(result[1][0]); //abc
alert(result[1][1]); //def
alert(result[1][2]); //ghi
alert(result[2]); //jkl
我的伙伴说这在.net中对他来说很好用,不幸的是我根本无法让它工作 - 只有在后面引用中返回任何组的最后一个匹配,如下所示:
(另外,任意一组可选都会造成混乱,设置全局标志也是如此)
var str = "@abc@def@ghi&jkl";
var regex = /(?:@([a-z]+))(?:&([a-z]+))/;
var result = str.match(regex);
alert(result[1]); //ghi
alert(result[1][0]); //g
alert(result[2]); //jkl
以下是我到达的解决方案,捕获相关的整个部分,并自己创建阵列:
var str = "@abc@def@ghi&jkl";
var regex = /^([@a-z]+)?(?:&([a-z]+))?$/;
var result = regex.exec(str);
alert(result[1]); //@abc@def@ghi
alert(result[2]); //jkl
var result1 = result[1].toString();
result[1] = result1.split('@')
alert(result[1][1]); //abc
alert(result[1][2]); //def
alert(result[1][3]); //ghi
alert(result[2]); //jkl
答案 0 :(得分:4)
这根本不是.match()
在JavaScript中的工作方式。返回的数组是一个简单字符串数组。捕获组没有“嵌套”;您只需从左到右计算(
个符号。
第一个字符串(索引[0]
)始终是整体匹配的字符串。然后是捕获组,每个数组元素一个字符串(或null
)。
您可以像往常一样,将结果数组重新排列到您心中的内容。它只是一个阵列。
编辑 - 哦,你的result[1][0]
是“g”的原因是应用于字符串的数组索引符号可以获得字符串的各个字符。