通过捕获括号分割正则表达式 - 浏览器支持:

时间:2014-07-17 07:18:34

标签: javascript regex cross-browser

看看这个样本:

>'1,2,3,4,5'.split(/,/)

结果:["1", "2", "3", "4", "5"]

但是看看这个样本:

>'1,2,3,4,5'.split(/(,)/)

结果:["1", ",", "2", ",", "3", ",", "4", ",", "5"]

来自MDN

  

如果separator是包含捕获的正则表达式   括号,然后每次分隔符匹配,结果   捕获括号的(包括任何未定义的结果)是   拼接到输出数组中。 但是,并非所有浏览器都支持此功能   能力。

问题:

在哪里可以找到支持该功能的浏览器(和版本)列表。

mdn没有公开该信息。

1 个答案:

答案 0 :(得分:5)

浏览器

Internet Explorer

Steven LevithanXRegExp网站的博客中,确认正确行为(包含捕获组在结果数组中捕获的文本)实施最多 Internet Explorer 8

我已经在browserstack上独立确认了这个结果,并且进一步确认,只有从版本10 开始,才能正确地为Internet Explorer正确实现带有捕获组的正则表达式时String.split的行为

以下是相关屏幕截图的链接:

附录

测试网站的完整源代码:

<html>
<head>
</head>
<body>
<script type="text/javascript">
document.write("<h1>Testing String.split, given regex with capturing group</h1>");

function runTest(num, actual, expected) {
    var equals = true;

    if (actual.length === expected.length) {
        for (var i = 0; i < actual.length; i++) {
            if (actual[i] !== expected[i]) {
                equals = false;
                break;
            }
        }  
    } else {
        equals = false;
    }

    document.write("<h2>Test " + num + ":</h2>");
    document.getElementsByTagName('body')[0].appendChild(document.createTextNode("'" + actual.join("'     '") + "'"));
    document.write(equals ? "<h2>Compliant to ECMA 5.1</h2>" : "<h2>NOT compliant to ECMA 5.1</h2>");
}
</script>
<script type="text/javascript">
runTest(1, '1,2,3,4,5'.split(/(,)/), ["1", ",", "2", ",", "3", ",", "4", ",", "5"]);
</script>

<script type="text/javascript">
runTest(2, 'ABCDEF'.split(/()/), ["A", "", "B", "", "C", "", "D", "", "E", "", "F"]);
</script>

<script type="text/javascript">
runTest(3, 'text<a>text</a>'.split(/<(\/)?([^>]+)>/), ["text", void 0, "a", "text", "/", "a", ""]);
</script>
</body>
</html>