在咱们的前端里面,常常会用到正则表达式进行检索字符串,恰好javascript里面提供RegExp来支持正则表达式,而RegExp对象的主要方法是exec()。 javascript
语法html
RegExpObject.exec(string)
参数 | 描述 |
string | 必需。要检索的字符串。 |
返回值:前端
返回一个数组,其中存放匹配的结果。若是未找到匹配,则返回值为 null。java
说明:web
exec() 方法的功能很是强大,它是一个通用的方法,并且使用起来也比 test() 方法以及支持正则表达式的 String 对象的方法更为复杂。正则表达式
若是 exec() 找到了匹配的文本,则返回一个结果数组。不然,返回 null。此数组的第 0 个元素是与正则表达式相匹配的文本,第 1 个元素是与 RegExpObject 的第 1 个子表达式相匹配的文本(若是有的话),第 2 个元素是与 RegExpObject 的第 2 个子表达式相匹配的文本(若是有的话),以此类推。除了数组元素和 length 属性以外,exec() 方法还返回两个属性。index 属性声明的是匹配文本的第一个字符的位置。input 属性则存放的是被检索的字符串 string。咱们能够看得出,在调用非全局的 RegExp 对象的 exec() 方法时,返回的数组与调用方法 String.match() 返回的数组是相同的。数组
可是,当 RegExpObject 是一个全局正则表达式时,exec() 的行为就稍微复杂一些。它会在 RegExpObject 的 lastIndex 属性指定的字符处开始检索字符串 string。当 exec() 找到了与表达式相匹配的文本时,在匹配后,它将把 RegExpObject 的 lastIndex 属性设置为匹配文本的最后一个字符的下一个位置。这就是说,您能够经过反复调用 exec() 方法来遍历字符串中的全部匹配文本。当 exec() 再也找不到匹配的文本时,它将返回 null,并把 lastIndex 属性重置为 0。spa
咱们如今主要来看说明里面的第三段的内容,code
看个例子:orm
<html> <body> <script type="text/javascript"> var str = "Visit W3School, W3School is a place to study web technology."; var patt = new RegExp("W3School","g"); var result; while ((result = patt.exec(str)) != null) { document.write(result); document.write("<br />"); document.write(patt.lastIndex); document.write("<br />"); } document.write(patt.lastIndex); </script> </body> </html>
运行结果以下:
W3School
14
W3School
24
0
能够看到在全局模式lastIndex会一直增长,直到遍历该字符串全部的字符,最后变为0,
因此有一个要注意的是,
若是在一个字符串中完成了一次模式匹配以后要开始检索新的字符串,就必须手动地把 lastIndex 属性重置为 0
示例以下:
var str = "Visit W3School, W3School is a place to study web technology."; var patt = new RegExp("W3School","g"); var result; result=patt.exec(str); document.write(result); document.write("<br />"); document.write(patt.lastIndex); document.write("<br />"); var aa="W3School sfd sfsf" var ddResult; ddResult= patt.exec(aa); document.write(ddResult);
结果以下:
W3School
14
null
之因此最后一个输出结果为null,是因为第一次匹配的结果的lastIndex变为14了。再去检索第二个字符串的时候会从14的位置开始,把前面13个字符去跳过去了,因此找不到,咱们要想其从头看是,只须要在检索第二个字符串的开头,让其LastIndex置为0
结果就会为:
W3School
14
W3School
但这只是全局的才有这个问题,局部的话,没有这个问题,能够把上面的例子的全局的去掉,就能够获得
var str = "Visit W3School, W3School is a place to study web technology."; var patt = new RegExp("W3School",""); var result; result=patt.exec(str); document.write(result); document.write("<br />"); document.write(patt.lastIndex); document.write("<br />"); var aa="W3School sfd sfsf" var ddResult; ddResult= patt.exec(aa); document.write(ddResult);
运行的结果以下:
W3School
0
W3School