js正则表达式 match exec test,以及g模式的一些知识点

关于js正则表达式的基本知识这里就不具体介绍了。这里主要讲几个方法的之间的区别。

区别:

a.match()是字符串的方法,exec()和test()是正则对象的方法.

b.match()方法和exec方法都返回数组,

   test()方法返回bool,表示模式和需要匹配的字符串是否匹配,匹配成功则返回true,否则返回false.主要用于判断是否存在匹配

下面描述一下match(),exec()的具体区别,代码后面的注释是给出的结果

1.match()

var text="cat, bat, sat, fat";
var pattern = /(.)at(..)/;
var matches = text.match(pattern);
alert(matches[0]);//cat,
alert(matches[1]);//c
alert(matches[2]);//,  

matches = text.match(pattern); 
alert(matches[0]);//cat, 
alert(matches[1]);//c 
alert(matches[2]);//,

//////////////////////////////////////    
var text="cat, bat, sat, fat";
var pattern = /(.)at(..)/g;
var matches = text.match(pattern);
alert(matches[0]);//cat,
alert(matches[1]);//bat,
alert(matches[2]);//sat,

matches = text.match(pattern);
alert(matches[0]);//cat,
alert(matches[1]);//bat,
alert(matches[2]);//sat,

match()不管是否带g(全局匹配),连续多次匹配获取的结果都一样

1.1match()不带g的匹配,

  1.1.1 第一次匹配,匹配返回的结果是个数组

          数组中的第0个是整个模式匹配的字符串,所以matches[0]=cat,

    之后的每一项(如果有)保存着与正则表达式中的捕捉组匹配的字符串,捕捉组在符号()内

    这里出现了2个捕捉组,分别为at前面的(.)和at后面的(..)

         所以,matches[1]=c matches[2]=,  这里是(, )逗号与空格,两个字符

  1.1.2 第二次匹配与第一次匹配结果完全一样

1.2match()带g的匹配

  1.2.1第一次匹配,匹配返回的结果是个数组

          带g的match匹配的数组中每个都是整个模式匹配的字符串

          所以,matches[0]=cat,  matches[1]=bat, matches[2]=sat,  最后都是(, )逗号与空格,两个字符

  1.2.2 第二次匹配与第一次匹配结果完全一样

exec

 var text="cat, bat, sat, fat";
 var pattern = /(.)at(..)/;
 var matches = pattern.exec(text);
 alert(matches[0]);//cat,
 alert(matches[1]);//c
 alert(matches[2]);//,  

 matches = pattern.exec(text);
 alert(matches[0]);//cat,
 alert(matches[1]);//c
 alert(matches[2]);//,
 
 var text="cat, bat, sat, fat";
 var pattern = /(.)at(..)/g;
 var matches = pattern.exec(text);
alert(matches[
0]);//cat, alert(matches[1]);//c alert(matches[2]);//, matches=pattern.exec(text);
alert(matches[0]);//bat, alert(matches[1]);//b alert(matches[2]);//,

exec(),与match()不一样,不带g时连续多次匹配获取的结果一样,而带g时在有多个匹配的情况下是不一样的

1.1exec()不带g的匹配,这个与前面的match()的不带g匹配完全一样

  1.1.1 第一次匹配,匹配返回的结果是个数组

          数组中的第0个是整个模式匹配的字符串,matches[0]=cat,

    之后的每一项(如果有)保存着与正则表达式中的捕捉组匹配的字符串,捕捉组在符号()内

    这里出现了2个捕捉组,分别为at前面的(.)和at后面的(..)

         所以,matches[1]=c matches[2]=,  这里是(, )逗号与空格,两个字符

  1.1.2 第二次匹配与第一次匹配结果完全一样

1.2exec()带g的匹配

  1.2.1第一次匹配,匹配返回的结果是个数组,这里与match()带g的第一次匹配不一样

          数组中的第0个是整个模式匹配的字符串,matches[0]=cat,

    之后的每一项(如果有)保存着与正则表达式中的捕捉组匹配的字符串,捕捉组在符号()内

    这里出现了2个捕捉组,分别为at前面的(.)和at后面的(..)

         所以,matches[1]=c matches[2]=,  这里是(, )逗号与空格,两个字符

  1.2.2 第二次匹配,匹配返回的结果也是个数组,但数组的具体信息则是继续匹配下一个字符串

   数组中的第0个是整个模式匹配的字符串,matches[0]=bat,

    之后的每一项(如果有)保存着与正则表达式中的捕捉组匹配的字符串,捕捉组在符号()内

    这里出现了2个捕捉组,分别为at前面的(.)和at后面的(..)

         所以,matches[1]=b matches[2]=,  这里是(, )逗号与空格,两个字符

 解释至这里我想大家应该都明白match()和exec()的区别了。

    导致这个区别的原因是由于javascript的RegExp对象中有一个属性叫lastIndex,当用exec进行操作的时候,lastIndex表示开始搜索下一个匹配项的字符位置.

当存在匹配的时候,该属性值会做改变。由于exec方法是RegExp这个对象的属性,所以这种情况只会在exec方法中出现,而不会在matches方法中出现。

   若我们是在一个循环中调用RegExp的exec方法,如果在设置g(全局搜索)的情况下,得到的结果不是我们想要的,那么可以再循环的最后添加下面的代码

1 pattern.lastIndex=0

这样每次循环后,又会从下一个待匹配的字符串的开始处进行匹配。

posted on 2012-10-30 23:18  清雅阁  阅读(1280)  评论(0编辑  收藏  举报

导航