js/javascript正则表达式中/g /i /m的用法,以及实例

正则的思想都是一样的,但是具体的写法会有所不同,在这里提到的/g,/i,/m在其他的地方也许就不能用了。

一,js正则标志/g,/i,/m说明

1,/g 表示该表达式将用来在输入字符串中查找所有可能的匹配,返回的结果可以是多个。如果不加/g最多只会匹配一个

2,/i  表示匹配的时候不区分大小写

3,/m 表示多行匹配,什么是多行匹配呢?就是匹配换行符两端的潜在匹配。影响正则中的^$符号


二,实例说明

1,/g的用法

<script type="text/javascript">   
str = "tankZHang (231144)"+   
"tank ying (155445)";   
res = str.match(/tank/);    //没有加/g   
alert(res);                 //显示一个tank   
  
res = str.match(/tank/g);   //加了/g   
alert(res);                 //显示为tank,tank   
<STRONG></script></STRONG>  


2,/i的用法


<script type="text/javascript">   
str = "tankZHang (231144)"+  "tank ying (155445)"; 
  
res = str.match(/zhang/);       
alert(res);                  //显示为null   
  
res = str.match(/zhang/i);   //加了/i   
alert(res);                  //显示为ZHang   
</script>  


3,/m的用法


<script type="text/javascript">   
var p = /$/mg;   
var s = '1\n2\n3\n4\n5\n6';   
alert(p.test(s));  //显示为true   
alert(RegExp.rightContext.replace(/\x0A/g, '\\a'));  //显示\a2\a3\a4\a5\a6   
alert(RegExp.leftContext);    //显示为竖的2345   
alert(RegExp.rightContext);   //显示为6   
  
var p = /$/g;   
var s = '1\n2\n3\n4\n5\n6';   
alert(p.test(s));  //显示为true   
alert(RegExp.rightContext.replace(/\x0A/g, '\\a'));  //什么都不显示   
alert(RegExp.leftContext);    //显示为竖的123456   
alert(RegExp.rightContext);   //什么都不显示   
  
var p = /^/mg;   
var s = '1\n2\n3\n4\n5\n6';   
alert(p.test(s));    //显示为true   
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //显示为1\a2\a3\a4\a5\a6   
alert(RegExp.leftContext);     //显示为竖的12345   
alert(RegExp.rightContext);    //显示为6   
</script>    
  
//从上例中可以看出/m影响的^$的分割方式 

上面说的三个例子,/i,/g,/m分开来说的,可以排列组合使用的。个人觉得/m没有多大用处

转载http://aabc99.blog.163.com/blog/static/163010810201132185918581/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值