正则表达式中的exec和match方法的区别

正则表达式中的execmatch方法的区别正则表达式

字符串的正则方法有:match()replace()search()split()数组

正则对象的方法有:exec()、test()app

1.match
match
方法属于String正则表达方法.
语法: str.match(regexp)
str:
要进行匹配的字符串. regexp:一个正则表达式(或者由RegExp()构形成的正则表达式)
match
的用法主要区分就是,正则表达式是否有全局标示g.
1)
若是有g全局标志,那么返回的数组保存的是,全部匹配的内容,不包过子匹配。
ide

2)若是没有g全局标志,那么返回的数组arr.arr[0]保存的是完整的匹配.arr[1]保存的是第一个括号里捕获的字串,依此类推arr[n]保存的是第n个括号捕获的内容.也就是当包含有全局的标志时则返回的结果第一个是正确匹配的结果,后面依次是子匹配的结果。spa

2.execcode

match方法不一样exec属于正则表达式的方法.
语法:var result1 = regexp.exec(str);
regexp:
正则表达式(能够直接定义也能够利用RegExp的方式定义) str:要匹配的字串
exec
match的关联就是exec(g有没有都无影响)就等价于不含有g全局标志的match.即返回数组arr[0]为匹配的完整串.其他的为括号里捕获的字符串(当含有子匹配时).
regexp

 

1若是exec执行的正则表达式没有子表达式(小括号内的内容,如/abc(\s*)/中的(\s*) ),若是有匹配,就返回第一个匹配的字符串内容,此时的类数组中的第一个元素为匹配的内容,(类数组中还包含有index:匹配字符串在原始字符串中的位置,input:输入的字符串)若是没有匹配返回null;orm

var reg = new RegExp("abc") ;
var str = "3abc4,5abc6";
alert(reg.exec(str));
alert(str.match(reg));

    执行如上代码,你会发现二者内容均为同样:abc,此时exec 中没有子表达式同时二者均为非全局的匹配xml

 

********子表达式捕获的内容就是指的第一个彻底匹配的字符串中在表达式匹配的部分
对象

var a=/^([^.]*)(?:\.(.+)|)$/;

var str="click.41646ass.sss";

var b=a.exec(str); console.log(b)

   输出["click.41646ass.sss", "click", "41646ass.sss"],正则表达式中共有三个括号可是第二个大括号采用?:的方法取消了捕获,也就是不输出匹配字符串中该子表达式匹配的部分,click对应([^.]*)41646ass.sss对应(.+),因此当为a=/^([^.]*)(\.(.+)|)$/时输出的结果为:["click.41646ass.sss", "click",".41646ass.sss" ,"41646ass.sss"].41646ass.sss对应于(?:\.(.+)|)

2、当execmatch中具备相同的子表达式且为非全局匹配时二者的输出也是相同的,同时输出的数组中含有的多个元素。

 

var str="visit W3cschool  a W3cschool bull";

var reg=new RegExp("W3c(school)");

var b=reg.exec(str);

console.log(b);

console.log(str.match(/W3c(school)/));

 

执行上诉代码的结果为W3cschool,school

三、当为全局匹配时

var str="visit W3cschool  a W3cschool bull";

var reg=new RegExp("W3cschool",'g');

var b=reg.exec(str);

console.log(b);

console.log(str.match(/W3cschool/g));

Exec中没有子表达式其输出为W3cschool,其输出只一个,match全局匹配时其输出元素中将包含全部的匹配项,其输出为W3cshcool,W3cschool

总结为:

(1)exec中无论是否是全局的匹配,只要没有子表达式,其返回的都只有一个元素,若是是全局匹配,能够利用lastIndex进行下一个匹配,匹配成功后lastIndex的值将会变为上次匹配的字符的最后一个位置的索引。在设置g属性后,虽然匹配结果不受g的影响,返回结果仍然是一个数组(第一个值是第一个匹配到的字符串,之后的为分组匹配内容),可是会改变index lastIndex等的值,将该对象的匹配的开始位置设置到紧接这匹配子串的字符位置,当第二次调用exec时,将从lastIndex所指示的字符位置 开始检索。一样match方法在设置了g属性后,也会改变indexlastIndex的值,可是是一次性的。没法像exec那样能逐过程累积,所以无 法累积获取下一次检索的位置。

  var patt = new RegExp('ab', 'g');

  var str = 'abcdef12ab34cd56ef';

  var ret;

  while((ret = patt.exec(str))!=null) {

    document.write(ret+"</br>");

    document.write("ret.input="+ret.input+"</br>");

    document.write("ret.index="+ret.index+"</br>");

    document.write("RegExp.lastIndex ="+patt.lastIndex +"</br>");

}

注意:当没有全局的变量g时,因为indexlastindex的值不会变化(除非手动修改),则会致使每次的陪匹配都是从字符串的头开始的,因此只要字符串中有匹配,就会致使死循环,当时设置g后,会自动改变前面的两个属性,会依次向后匹配直到没有匹配项退出循环

输出结果:

ab
ret.input=abcdef12ab34cd56ef
ret.index=0
RegExp.lastIndex =2
ab
ret.input=abcdef12ab34cd56ef
ret.index=8
RegExp.lastIndex =10

(2)Match在非全局匹配时其余几种状况下(有无子匹配的状况下)的返回结果和exec是相同的,在全局匹配时其将返回包含全部匹配项的数组(其中不包含子匹配)。

(3)exec返回的是类数组而match返回的则是数组

相关文章
相关标签/搜索