JavaScript:正则表达式 问号

问号

1.?表示重复前面内容的0次或一次(但尽可能多重复)

var reg=/abc?/g;
var str="abcdabcaba";
console.log(str.match(reg));  //abc,abc,ab

2.??表示重复前面内容的0次或一次(但尽可能少重复)

var reg=/abc??/g;
var str="abcdabcaba";
console.log(str.match(reg));  //ab,ab,ab

3.惰性量词 

正则中的量词都为贪婪量词,但在后面加上?就成了惰性量词。

var reg=/a\w+/g;
var str="abcdabcaba";
console.log(str.match(reg));  //abcdabcaba
var reg=/a\w+?/g;
var str="abcdabcaba";
console.log(str.match(reg));  //ab ab ab

4.前瞻(?=,?!)

  上一页

5.不捕捉模式(?:)

 var reg=/(?:abc)(de)(fg)/g;
 var str="abcd abcde abcdefg abcabc";
 console.dir(reg.exec(str));

 分组中的 非捕获性分组 

 注意:

 ?=    ?!是零宽断言,正则表达式引擎会留意字符串后面的部分,然而却不移动index 

 ?:正则表达式是会移动index的。

   var str="abcdedd";
   var re=/(?:d)/g;
   show(5);
   console.dir(str.match(re));
   function show(num){
      for(var i=0;i<num;i++){
        console.dir(re.exec(str));console.log("");
      }
   }

 var str="abcdedd";
   var re=/(?=d)/g;
   show(5);
   console.dir(str.match(re));

var str="abcdedd";
   var re=/(?!d)/g;
   show(5);
   console.dir(str.match(re));

发现前瞻查找的只是位置,不是内容。

 

 var str="abcdedd";
   var re=/(?=d)de/g;
   show(3);
   console.dir(str.match(re));

posted @ 2013-10-17 13:35  hongdada  阅读(1058)  评论(0编辑  收藏  举报