JavaScript 正则表达式相关理解

1 使用正则的test、exec方法而且带有g属性进行连续匹配的时候, 如果每次匹配之前 lastIndex属性没有清零。<script>var str= 1

1.使用正则的test、exec方法而且带有g属性进行连续匹配的时候, 如果每次匹配之前 lastIndex属性没有清零。

  <script>
        var str='123qweQWE125|2q3qw 3aa!*&%#)';
        var re=new RegExp("2",'g');
        for(var i=0;i<10;i++){
            console.log(re.test(str)+' '+re.lastIndex);
        }
    </script>

可以看到每次匹配都是从上次匹配结束的位置开始,匹配完后,下次会从头开始匹配。如果没有g属性,则每次都是从头开始匹配。

2.正则表达式字面量和使用构造函数共享RegExp实例的问题

  <script>
        var re = null,i;
        for (i=0;i<10;i++){
            re = /cat/g;
            console.log(re.test('catastronphe')+" "+re.lastIndex);
        }
        for (i=0;i<10;i++){
            re = new RegExp('cat','g');
            console.log(re.test('catastronphe')+" "+re.lastIndex);
        }
    </script>

高程上说使用正则表达式字面量和使用RegExp构造函数创建的正则表达式不一样。在ECMAScript 3中,正则表达式字面量始终会共享同一个RegExp实例,而

使用构造函数创建的每一个新RegExp实例都是一个新实例。但是在ECMAScript 5中明确规定,使用正则表达式字面量必须像直接调用RegExp构造函数一样,

每次都创造新的RegExp实例,所以在chrome上都是一样的。

3.正则字面量和正则对象在匹配转义字符时的差别

    <script>
        var str='123qweQWE125|2q3qw 3aa!*&%#)';
//      var re=new RegExp("\\s",'g');
        var re=/\s/g;
        for(var i=0;i<10;i++){
            console.log(re.exec(str)+' '+re.lastIndex);
        }
    </script>

 代码中正则字面量和正则对象是等效的,但是正则对象内多了一个‘\’,我理解为正则对象内设置匹配时用双引号,说明是一个字符串,在使用中字符串会转换成正则

表达式时会去掉一层转义字符。

 4.使用匹配子选项

 <script>
        var a='name=yanghaipin';
        var b= a.match(/^(name)=(.+)/);
        console.log(b);
    </script>

使用小括号将子选项包起来,match返回的是一个数组,第一个是完整匹配到的字符串,剩下的分别是匹配到的子选项。

 5.使用(?:)(?=)

 <script>
        var str='windows 10 is great';
        var a=str.match(/windows (?=\d+)/);
        var b=str.match(/windows (?:\d+)/);
        var c=str.match(/windows (\d+)/);
        alert(a);//windows
        alert(b);//windows 10
        alert(c);//windows 10,10
    </script>

(?:)和(?=)都会作为匹配校验,但是前者会出现在匹配到的字符串里面,后者不会出现。

 5. 关于 exec 和 match 方法的区别

http://www.cnblogs.com/withasi/archive/2012/04/23/2466933.html

6 可以使用 $ 来匹配字匹配项

    var now = new Date().toLocaleDateString();
    console.log(now);
    var regdate=/^(\d{4})[/-](\d{1,2})[/-](\d{1,2})/;
    console.log(now.match(regdate));
    console.log(now.replace(regdate,"$1年$2月$3日"));