正则表达式的g m $ ^ i

表达式加上参数g之后,表明可以进行全局匹配,注意这里“可以”的含义。我们详细叙述: 

1)对于表达式对象的exec方法,不加入g,则只返回第一个匹配,无论执行多少次均是如此,如果加入g,则第一次执行也返回第一个匹配,再执行返回第二个匹配,依次类推。例如 
var regx=/user\d/; 
var str=“user18dsdfuser2dsfsd”; 
var rs=regx.exec(str);//此时rs的值为{user1} 
var rs2=regx.exec(str);//此时rs的值依然为{user1} 
如果regx=/user\d/g;则rs的值为{user1},rs2的值为{user2} 
通过这个例子说明:对于exec方法,表达式加入了g,并不是说执行exec方法就可以返回所有的匹配,而是说加入了g之后,我可以通过某种方式得到所有的匹配,这里的“方式”对于exec而言,就是依次执行这个方法即可。 

2)对于表达式对象的test方法,加入g于不加上g没有什么区别,因为该方法返回的是一个boolean型。 

3)对于String对象的match方法,不加入g,也只是返回第一个匹配,一直执行match方法也总是返回第一个匹配,加入g,则一次返回所有的匹配(注意这与表达式对象的exec方法不同,对于exec而言,表达式即使加上了g,也不会一次返回所有的匹配)。例如: 
var regx=/user\d/; 
var str=“user1sdfsffuser2dfsdf”; 
var rs=str.match(regx);//此时rs的值为{user1} 
var rs2=str.match(regx);//此时rs的值依然为{user1} 
如果regx=/user\d/g,则rs的值为{user1,user2},rs2的值也为{user1,user2} 

4)对于String对象的replace方法,表达式不加入g,则只替换第一个匹配,如果加入g,则替换所有匹配。(开头的三道测试题能很好的说明这一点) 

5)对于String对象的split方法,加上g与不加g是一样的,即: 
var sep=/user\d/; 
var array=“user1dfsfuser2dfsf”.split(sep); 
则array的值为{dfsf, dfsf} 
此时sep=/user\d/g,返回值是一样的。 

6)对于String对象的search方法,加不加g也是一样的,因为该方法返回第一个和规则匹配的子字符串的起始位置,如果没有匹配的子字符串则返回-1,search() 方法不执行全局匹配,它将忽略标志 g。 

总结2:附加参数m的用法 

附加参数m,表明可以进行多行匹配,但是这个只有当使用^和$模式时才会起作用,在其他的模式中,加不加入m都可以进行多行匹配(其实说多行的字符串也是一个普通字符串),我们举例说明这一点 

1)使用^的例子 
var str="bd76dfsdfsdfsdfs\r\nb76dsfsdb8fsdf"; //匹配以b开头的除\n外的任意字符,第一行bd匹配,第二行b7匹配,b8为什么不匹配?因为不是字符串的开头哇。。。m的作用就在此,匹配多行中以b开头的除\n外的任意字符的字符串,还有就是\r\n在windows中是换行的意思.
var pattern=/^b./gm;
alert(str.match(pattern));

此时加入g和不加入g,都只返回第一个匹配{bd},如果regx=/^b./gm,则返回所有的匹配{bd,b7},注意如果regx=/^b./m,则也只返回第一个匹配。所以,加入m表明可以进行多行匹配,加入g表明可以进行全局匹配,综合到一起就是可以进行多行全局匹配 

2)使用其他模式的例子,例如 
var regx=/user\d/; 
var str=“sdfsfsdfsdf sdfsuser3 \r\ndffs \r\nb76dsf user6”; 
var rs=str.match(regx); 
此时不加参数g,则返回{user3},加入参数g返回{user3,user6},加不加入m对此没有影响。 

3)因此对于m我们要清楚它的使用,记住它只对^和$模式起作用,在这两种模式中,m的作用为:如果不加入m,则只能在第一行进行匹配,如果加入m则可以在所有的行进行匹配。我们再看一个^的例子 
var regx=/^b./; 
var str=“ret76 dfsdf \r\nbjfsdfs dffs \r\nb76dsf sdfsdf”; 
var rs=str.match(regx); 
此时rs的值为null,如果加入g,rs的值仍然为null,如果加入m,则rs的值为{bj}(也就是说,在第一行没有找到匹配,因为有参数m,所以可以继续去下面的行去找是否有匹配),如果m和g都加上,则返回{bj,b7}(只加m不加g说明,可以去多行进行匹配,但是找到一个匹配后就返回,加入g 表明将多行中所有的匹配返回,当然对于match方法是如此,对于exec呢,则需要执行多次才能依次返回) 

总结3:在HTML的textarea输入域中,按一个Enter键,对应的控制字符为“\r\n”,即“回车换行”,而不是“\n\r”,即“换行回车”,我们看一个前面我们举过的例子: 
var regx=/a\r\nbc/; 
var str=“a\r\nbc”; 
var rs=regx.exec(str); 
结果:匹配成功,rs的值为:{a\r\nbc },如果表达式为/a\n\rbc/,则不会被匹配,因此在一般的编辑器中一个”Enter”键代表着“回车换行”,而非“换行回车”,至少在textarea域中是这样的。 

示例:

 

ContractedBlock.gif ExpandedBlockStart.gif Code
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
function aa(){
    
var test=document.getElementById('test').value;
    
var regural=/a\r\nbc/;
        alert(regural.exec(test));
}
</script>
</head>
<body>
<textarea id="test">
</textarea>
<input type="button" onclick="aa();"  value="测试"/>
</body>
</html>

结果 :



 

开头的  /^   : ^ 匹配输入字符串的开始位置  


结尾的  $/   : $ 匹配输入字符串的结尾位置。


g   /global   代表全局搜索   
    
i   /ignore   代表忽略大小写


 

JavaScript exec() 方法

 

 

定义和用法

exec() 方法用于检索字符串中的正则表达式的匹配。

语法

RegExpObject.exec(string)
参数描述
string必需。要检索的字符串。

返回值

返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。

说明

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。

 

提示和注释

重要事项:如果在一个字符串中完成了一次模式匹配之后要开始检索新的字符串,就必须手动地把 lastIndex 属性重置为 0。

提示:请注意,无论 RegExpObject 是否是全局模式,exec() 都会把完整的细节添加到它返回的数组中。这就是 exec() 与 String.match() 的不同之处,后者在全局模式下返回的信息要少得多。因此我们可以这么说,在循环中反复地调用 exec() 方法是唯一一种获得全局模式的完整模式匹配信息的方法。

代码
< 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 /> " );
 }
</ script >

</ body >
</ html >

W3School
14
W3School
24

 

 

 

转载于:https://www.cnblogs.com/jhxk/articles/1611489.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值