JS正则中的match与exec使用说明

主要参考W3C教程

String.match()

match() 方法将检索目标字符串,以找到一个或多个与 正则表达式regexp 匹配的文本。match()有两种情况:

<!--[if !supportLists]-->1、 <!--[endif]-->如果 regexp 具有标志 g,则 match() 方法将执行全局检索,找到目标字符串中的所有匹配子字符串。











匹配情况

返回值

没有找到任何匹配的子串

null

找到了一个或多个匹配子串

一个数组。数组的内容包含所有的匹配子串

下面是个实例:


代码如下:

var str = 'xxtest00test11test22test'
regexp = new RegExp(/(test)(.{1})/g);
while((result = regexp.exec(str)) != null){
document.write(result + '<br />');
document.write(regexp.lastIndex+ '<br />');
}

匹配的结果如下:

返回的匹配数组:

[testaa,testbb,testcc]
并且数组不包含其他有关匹配的信息:

0:testaa
   1:testbb
   2:testcc

<!--[if !supportLists]-->2、 <!--[endif]-->如果 regexp 没有标志 g,那么 match() 方法就只能目标字符串中执行一次匹配。












匹配情况

返回值

没有找到任何匹配的子串

null

找到了一个或多个匹配子串

一个数组。数组的内容包含与它找到的匹配文本有关的信息。该数组的第 0 个元素存放的是匹配文本,而其余的元素存放的是与正则表达式的子表达式匹配的文本。除了这些常规的数组元素之外,返回的数组还含有两个对象属性。index 属性声明的是匹配文本的起始字符在目标字符串中的位置,input 属性声明的是对目标字符串的引用。

我们把上面例子的全局标志g拿掉,regexp = new RegExp(/(test)(.{1})/);再次得到的匹配结果如下:

返回的匹配数组:

[test0,test,0]
并且数组包含index和input信息:

0:test0
1:test
2:0
index:2
input:xxtest0test1test2test

不过有一点需要说明的是,在IE6,7,8下,返回的数组同时包含lastIndex信息,用来表示表示匹配子串的下一个位置。话说这个属性应该是在regexp上面的,所以在IE9里面去掉了。

String.exec()方法:

<!--[if !supportLists]-->1、 <!--[endif]-->如果 regexp 不具有标志 g。












匹配情况

返回值

没有找到任何匹配的子串

null

找到了一个或多个匹配子串

一个数组。数组的内容与调用match() 返回的数组是相同的。

沿用上面的例子:


代码如下:

result = regexp.exec(str);

返回的匹配数组:
[test0,test,0]
并且数组包含index和input信息:
0:test0
1:test
2:0
index:2
input:xxtest0test1test2test
同样,在IE6,7,8下,返回的数组同时包含lastIndex信息。
<!--[if !supportLists]-->2、 <!--[endif]-->如果 regexp 具有标志 g。
它会在 regexp的 lastIndex 属性指定的字符处开始检索。当 exec() 找到了与表达式相匹配的文本时,在匹配后,它将把 regexp的 lastIndex 属性设置为匹配文本的最后一个字符的下一个位置。这就是说,可以通过反复调用 exec() 方法来遍历字符串中的所有匹配文本。当 exec() 再也找不到匹配的文本时,它将返回 null,并把 lastIndex 属性重置为 0。
注:无论 RegExpObject 是否是全局模式,exec() 都会把完整的细节添加到它返回的数组中。这就是 exec() 与 match() 的不同之处,后者在全局模式下返回的信息要少得多。如果要获得所有的匹配细节,就可以在全局模式下循环调用exec()方法。
类似:


代码如下:

var str = 'xxtest00test11test22test'
regexp = new RegExp(/(test)(.{1})/g);
while((result = regexp.exec(str)) != null){
document.write(result + '<br />');
document.write(regexp.lastIndex+ '<br />');
}

对于lastIndex属性的说明:
<!--[if !supportLists]-->(1) <!--[endif]-->lastIndex在regexp上面,而不是返回的数组结果里面,IE6,7,8在match()方法的lastIndex实现上有bug。
<!--[if !supportLists]-->(2) <!--[endif]-->如果在一个字符串中完成了一次模式匹配之后要开始检索新的字符串,就必须手动地把 lastIndex 属性重置为 0。

(0)

相关推荐

  • JS常见疑难点分析之match,charAt,charCodeAt,map,search用法分析

    本文实例讲述了JS常见疑难点分析之match,charAt,charCodeAt,map,search用法.分享给大家供大家参考,具体如下: JavaScript match() 方法 定义和用法 match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配. 该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置. 语法 匹配字符串,返回指定的值 stringObject.match(searchvalue) 匹配正则,返回指定

  • js正则表达式之search方法讲解

    功能:返回与正则表达式查找内容匹配的第一个子字符串的位置 语法:stringObj.search(rgExp) stringObj 必选项 rgExp正则表达式 返回值:search 方法指明是否存在相应的匹配.如果找到一个匹配,search方法将返回一个整数值,指明这个匹配距离字符串开始的偏移位置.如果没有找到匹配,则返回 -1 示例代码: 复制代码 代码如下: <html> <script language="javascript" type="text

  • js正则函数match、exec、test、search、replace、split使用介绍集合

    match 方法 使用正则表达式模式对字符串执行查找,并将包含查找的结果作为数组返回. stringObj.match(rgExp) 参数 stringObj 必选项.对其进行查找的 String 对象或字符串文字. rgExp 必选项.为包含正则表达式模式和可用标志的正则表达式对象.也可以是包含正则表达式模式和可用标志的变量名或字符串文字. 其余说明与exec一样,不同的是如果match的表达式匹配了全局标记g将出现所有匹配项,而不用循环,但所有匹配中不会包含子匹配项. 例子1: functi

  • JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)

    JavaScript charCodeAt 方法 charCodeAt 方法用于从字符串中取得指定位置字符的 Unicode 编码.其语法如下: 复制代码 代码如下: str_object.charCodeAt( x ) 参数说明: 参数 说明 str_object 要操作的字符串(对象) x 必需.表示位置的数字 提示:字符串是从 0 开始计数的. charCodeAt 方法实例 复制代码 代码如下: <script language="JavaScript"> docu

  • javascript中match函数的用法小结

    javascript中的match函数是使用正则表达式对字符串进行查找,并将查找的结果作为数组返回,在实际开发中非常的有用,使用方法如下: stringObj.match(rgExp) 其中stringObj是必选项.对其进行查找的 String 对象或字符串文字. rgExp是必选项.为包含正则表达式模式和可用标志的正则表达式对象.也可以是包含正则表达式模式和可用标志的变量名或字符串文字. 如果javascript中match函数方法没有找到匹配,返回 null.如果找到匹配返回一个数组并且更

  • js Map List 遍历使用示例

    Map (exMap:{"name":"abc","sex",'male'}): 在不知道key的情况下遍历map: 网上说过这种方法: 复制代码 代码如下: for(var key in exMap){ Console.write("key:"+key+";value:"+exMap[key]);//经我考证,the key is undefined.So the method is not right.

  • 简介JavaScript中charAt()方法的使用

    这个方法返回从指定索引的字符. 字符串中的字符进行索引从左向右.第一个字符的索引是0,并且在一个叫 stringName字符串的最后一个字符的索引是stringName.length- 1. 语法 string.charAt(index); 下面是参数的详细信息: index: 介于0和1比串的长度以下的整数. 返回值: 返回从指定索引的字符. 例子: <html> <head> <title>JavaScript String charAt() Method</

  • js正则表达式之match函数讲解

    功能:使用正则表达式模式对字符串执行查找,并将包含查找的结果作为数组返回 函数格式:stringObj.match(rgExp) stringObj为字符串必选 rgExp为正则表达式必选项 返回值:如果能匹配则返回结果数组,如果不能匹配返回null 复制代码 代码如下: <html> <script language="javascript" type="text/javascript"> //使用正则表达式模式对字符串执行查找,并将包含查

  • js charAt的使用示例

    eg: 复制代码 代码如下: <html> <body> <script type="text/javascript"> var str="Hello world!" document.write("The first character is: " + str.charAt(0) + "<br />") document.write("The second chara

  • JS Map 和 List 的简单实现代码

    复制代码 代码如下: /* * MAP对象,实现MAP功能 * * 接口: * size()     获取MAP元素个数 * isEmpty()    判断MAP是否为空 * clear()     删除MAP所有元素 * put(key, value)   向MAP中增加元素(key, value)  * remove(key)    删除指定KEY的元素,成功返回True,失败返回False * get(key)    获取指定KEY的元素值VALUE,失败返回NULL * element(

  • js实现的map方法示例代码

    复制代码 代码如下: /** * * 描述:js实现的map方法 * @returns {Map} */ function Map(){ var struct = function(key, value) { this.key = key; this.value = value; }; // 添加map键值对 var put = function(key, value){ for (var i = 0; i < this.arr.length; i++) { if ( this.arr[i].k

  • js中exec、test、match、search、replace、split用法

    exec:对string进行正则处理,并返回匹配结果.array[0]为原字符串,array[i]为匹配在整个被搜索字符串中的位置. test:测试string是否包含有匹配结果,包含返回true,不包含返回false. match(pattern) :根据pattern进行正则匹配,如果匹配到,返回匹配结果,如匹配不到返回null search(pattern) :根据pattern进行正则匹配,如果匹配到一个结果,则返回它的索引数;否则返回-1 replace(pattern,replace

随机推荐