Javascript正则表达式意外输出

时间:2015-07-06 08:45:44

标签: javascript arrays regex node.js

我尝试使用node在css文件上执行 regex

这是我的javascript:

var fs = require ('fs');

fs.readFile('test.css','utf8',function(error,css){
if(error){
    console.log("I'm sorry, something went terribly wrong :o Here's the message: "+error);
}



var matches = css.match(/([a-zA-Z-]+):\s*([0-9]+)(vh|VH|vw|VW)/g);

    console.log(matches[2][1]);



});

运行时的预期输出:

regex101 output

实际输出: actual output

正如你所看到的,它并没有像预期的那样将每个匹配放在它自己的数组中,它只是将所有内容放在一个没有任何子数组的巨型数组中。 我能做什么?

4 个答案:

答案 0 :(得分:1)

在这种情况下,

match不会为您提供详细的匹配结果:

  

如果正则表达式包含g标志,则该方法返回一个包含所有匹配的子字符串而不是匹配对象的数组。

您可以改为使用exec

var regex = /([a-zA-Z-]+):\s*([0-9]+)(vh|VH|vw|VW)/g;
var css = "body{\nfont-size: 10vw;\n height: 500vh\n}";
var match;

while (match = r.exec(css)){
    console.log(match)
}

这给出了这个输出:

["font-size: 10vw", "font-size", "10", "vw", index: 6, input: "body{↵font-size: 10vw;↵ height: 500vh↵}"]  
["height: 500vh", "height", "500", "vh", index: 24, input: "body{↵font-size: 10vw;↵ height: 500vh↵}"]

答案 1 :(得分:1)

var reg = /([a-zA-Z-]+):\s*([0-9]+)(vh|VH|vw|VW)/g;
var matches = [];
var m;

while ((m = reg.exec(css)) !== null) {
    if (m.index === reg.lastIndex) {
        reg.lastIndex++;
    }
    matches.push(m);
}

console.log(matches);

答案 2 :(得分:1)

实际上是预期的行为。如果将string.match方法与全局标志一起使用,则括号不会在匹配内创建组:

var str = "javascript is cool";
var result = str.match( /JAVA(SCRIPT)/g );
console.log( result[0] ); // javascript
console.log( result.length ); //1

您的案例正在使用regexp.exec(str)。它可以找到所有匹配和括号组。

var str = 'javascript is cool. Use javascript';

var regexp = /java(script)/g;

while (result = regexp.exec(str)) {   
  console.log(result.length);   //2
  console.log(result[0]);  //javascript
  console.log(result[1]);  //script 
} 

答案 3 :(得分:0)

根据以上答案,我设法提出以下代码:

while(match = css.match(/([a-zA-Z-]+):\s*([0-9]+)(vh|VH|vw|VW)/)){
        matches.push(match);
        css = css.replace(match[0],'');
}

非常感谢大家的帮助!